Compare commits
	
		
			244 Commits
		
	
	
		
			2024.04.10
			...
			pr-1659-Wi
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 0e861aaf79 | ||
|   | e57874d3cc | ||
|   | f8f1b327c0 | ||
|   | 17c499945f | ||
|   | dbbe200623 | ||
|   | eaf2ef194b | ||
|   | 39f281f428 | ||
|   | 86655d7831 | ||
| ![allcontributors[bot]](/assets/img/avatar_default.png)  | 56ec37aec1 | ||
|   | 9261e78237 | ||
|   | 317a2ee7d3 | ||
|   | 9851037608 | ||
|   | 4273a1880b | ||
|   | 1d437287b8 | ||
|   | b0830edb4a | ||
| 091a64fbe9 | |||
| 4d7c331984 | |||
| 31b89aa9b0 | |||
|   | 72a2ef5fc9 | ||
|   | c1fd596841 | ||
|   | 3743a55e0d | ||
|   | b04fe6a16d | ||
| 455f18be13 | |||
|   | ca0b544251 | ||
|   | 09cb746b93 | ||
|   | 31446987ea | ||
|   | 10ecb680cd | ||
| 055c6b6a2b | |||
|   | 2d44ecf8a6 | ||
|   | bba6ffe74f | ||
|   | 7025dfccc6 | ||
|   | 37a938be33 | ||
| 7c3424f001 | |||
| 155691f94b | |||
| a5ec96a56f | |||
|   | e6bedf136d | ||
|   | fa64257fcd | ||
| 82fb92114b | |||
|   | f76be45a40 | ||
|   | 7c66d26061 | ||
| 12c58d567c | |||
| d62e221615 | |||
| 0b78517a9d | |||
|   | 9d05fe7cb2 | ||
|   | d4f8370fc3 | ||
|   | 54094cc1f8 | ||
|   | 1c30ca8cbc | ||
|   | 3573915166 | ||
|   | d98db5bb3b | ||
| 03776a36cc | |||
|   | 1c34054d36 | ||
|   | 8e6b047b93 | ||
|   | 4b445b6267 | ||
|   | 87efd23aa3 | ||
|   | 31bbc01b1c | ||
|   | d0a72cb8d5 | ||
|   | 98b64720f6 | ||
|   | 8f7de57114 | ||
| 0c0ae8f988 | |||
|   | 671e45fdbf | ||
|   | d7230c03f2 | ||
| b4410c0cfb | |||
|   | 6bc376fb63 | ||
|   | a15754a9ef | ||
|   | 321d14b66d | ||
|   | 3bcbd63120 | ||
|   | 78e3f5e599 | ||
|   | ea3ea1a5c6 | ||
|   | 905ace5334 | ||
|   | 756daeec8b | ||
|   | 2eb8f609dd | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | fbc5e7937a | ||
|   | 7e9f13ec33 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 6f65512707 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 91c2d660c6 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 71bd6bf7f0 | ||
| 31ba6da98d | |||
|   | 7191a6d548 | ||
| 4bd9c6ca20 | |||
|   | ec0701bfa8 | ||
| f80027ec43 | |||
| 76e1ceb95c | |||
|   | bbf7e6953e | ||
| f09b310bde | |||
| 4bc6403633 | |||
|   | b1c63004f2 | ||
|   | 102693168a | ||
| 4f505086f8 | |||
| 8dcc58b110 | |||
| a2528d9d2c | |||
|   | a334e449cb | ||
|   | 574eedb875 | ||
| ae68a612ef | |||
|   | 9eebf17660 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 845839b486 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | c656c175f5 | ||
|   | 64087d6749 | ||
|   | 7b3e6ab536 | ||
|   | 672953b035 | ||
|   | 3fefe84f17 | ||
|   | 12be85b9d2 | ||
| 508534e2ba | |||
|   | 09985fa173 | ||
| 4332470e91 | |||
| 0d332e72b5 | |||
|   | f34ac66e7a | ||
| 4c33224d5f | |||
| b6529e4a58 | |||
| ![allcontributors[bot]](/assets/img/avatar_default.png)  | 1bdbf3bfa3 | ||
| 986da833ad | |||
| ![allcontributors[bot]](/assets/img/avatar_default.png)  | ac0b8580b6 | ||
|   | 989393d3d9 | ||
| 367b9e548d | |||
|   | 5591ac8697 | ||
| d3163a1e53 | |||
| 53eaa1eee9 | |||
|   | 938ea2535f | ||
|   | 19e7c1451f | ||
|   | f30b5d8183 | ||
|   | bd5afa3a9a | ||
| 1496586617 | |||
|   | 95d6ec9fd4 | ||
|   | 4de78f3c58 | ||
|   | 116e31b45d | ||
|   | 4ab64e727d | ||
|   | 2deb9e3d6f | ||
|   | 75282d0a3a | ||
|   | 17286cfeaf | ||
|   | bab8f88a13 | ||
|   | e49d2df4b7 | ||
|   | 1b8f5eb531 | ||
|   | d7c0f0d495 | ||
|   | c0481d65d0 | ||
|   | 42b75c9265 | ||
| 9ad1c6450a | |||
| 9d13fafa89 | |||
|   | 11f3f8ac13 | ||
| 7c41b2ae77 | |||
| 687c5afb20 | |||
|   | e64f6aab7d | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | de0fff5801 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 6a62210f15 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 6410f2d953 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | c88caedad8 | ||
|   | 6eec31b9f3 | ||
| 04e6f2a2c6 | |||
| a58f090e79 | |||
|   | a7662a1b55 | ||
|   | 8850bcd6cc | ||
| d28db8262a | |||
|   | ff191d6661 | ||
|   | 265998f86f | ||
|   | 2dde416f50 | ||
|   | e92210a88f | ||
|   | 84d33ed944 | ||
|   | 87377a4e8a | ||
|   | 00b3ddd217 | ||
|   | 84fe22fc7d | ||
|   | a81e0f3371 | ||
|   | f16ed5024b | ||
|   | f399643dff | ||
|   | 70f2ae7405 | ||
|   | 8158e73aed | ||
|   | ad14bf5574 | ||
| 1b99537a5f | |||
| 0d3f4681e0 | |||
|   | cbee839671 | ||
|   | 67cdae5585 | ||
|   | 503a240d01 | ||
|   | 200bf71906 | ||
|   | 530901d99b | ||
| ![allcontributors[bot]](/assets/img/avatar_default.png)  | abc00c3a96 | ||
|   | 1bb06b7db1 | ||
| 34ae172d92 | |||
| 7e0218b082 | |||
| 0a9a24d390 | |||
|   | 291fb49af2 | ||
|   | 6d51572142 | ||
|   | 5facb997ee | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | f96e9bf7dc | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | b0106bfd6b | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | a366327b79 | ||
|   | 6047727d0f | ||
|   | 90831803d0 | ||
|   | 4d859ea13a | ||
| 9a489cd130 | |||
| ![allcontributors[bot]](/assets/img/avatar_default.png)  | b9ef360d25 | ||
|   | 99822dae1e | ||
|   | 28d9794686 | ||
|   | a5a2ed0fdd | ||
|   | 6493cc2076 | ||
|   | 3d569ae40c | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 1ae83dc7ae | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 66edb72826 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | df3583efab | ||
| 44f35581a9 | |||
| 0a0e8b605d | |||
|   | 0bc8336b6a | ||
|   | 3ace34099b | ||
|   | e4ee74ea29 | ||
|   | 9aee2381f7 | ||
| 0ea286bf8e | |||
|   | 13f1bd19a4 | ||
|   | 2b97f64f3b | ||
| c19f554b77 | |||
| 66847abdaf | |||
| 32e65cf3e8 | |||
| 87aa1586f3 | |||
|   | 9ed7abb972 | ||
| 4221863aff | |||
| 26f3300424 | |||
|   | 2356a3a49b | ||
|   | 4f26072136 | ||
|   | 3d8eda7bff | ||
|   | e0b1995d20 | ||
|   | 560a46ff03 | ||
|   | f1a0679bd3 | ||
|   | c64d446d52 | ||
|   | 25a6a5a937 | ||
|   | 8e51dcb5aa | ||
| 1ce9941018 | |||
| ![allcontributors[bot]](/assets/img/avatar_default.png)  | 5b0f3a6832 | ||
| ece4a76711 | |||
|   | 33474d79e2 | ||
|   | f82cd36298 | ||
| c830c0cf30 | |||
|   | 61ade2c055 | ||
|   | 0d1e4d88f6 | ||
|   | 266f92811c | ||
|   | 1633232fd5 | ||
|   | 03a35288ec | ||
| 7346c4d3ac | |||
|   | e46cb94c86 | ||
| c0139de0e1 | |||
|   | 1df7bd988f | ||
|   | f762b5c3f5 | ||
|   | a8a4adee73 | ||
|   | 93136f2a0b | ||
|   | 5d405830df | ||
| d80af3968f | |||
|   | 09d3669fcf | ||
| c4c68f7f7e | |||
|   | a80653968e | ||
| 775ff52b14 | 
							
								
								
									
										2973
									
								
								.all-contributorsrc
									
									
									
									
									
										Normal file
									
								
							
							
						
						
							
								
								
									
										1
									
								
								.cache/plugin/social/fonts
									
									
									
									
									
										Symbolic link
									
								
							
							
						
						| @@ -0,0 +1 @@ | ||||
| ../../../theme/assets/brand/fonts | ||||
| @@ -4,5 +4,5 @@ | ||||
| 	"name": "Privacy Guides", | ||||
| 	"image": "ghcr.io/squidfunk/mkdocs-material:9.5.17", | ||||
| 	"forwardPorts": [8000], | ||||
|   "postCreateCommand": "git submodule init; git submodule update theme/assets/brand; mkdocs serve --dev-addr=0.0.0.0:8000 --config-file config/mkdocs.en.yml" | ||||
|   "postCreateCommand": "git submodule init; git submodule update theme/assets/brand; apk add bash; /bin/bash run.sh --cmd=mkdocs --cmd_flags=--dev-addr=0.0.0.0:8000" | ||||
| } | ||||
|   | ||||
| @@ -4,5 +4,5 @@ | ||||
| 	"name": "Privacy Guides Team", | ||||
| 	"image": "ghcr.io/privacyguides/privacyguides.org:main", | ||||
| 	"forwardPorts": [8000], | ||||
|   "postCreateCommand": "git submodule init; git submodule update theme/assets/brand; MKDOCS_INHERIT=mkdocs-production.yml mkdocs serve --dev-addr=0.0.0.0:8000 --config-file config/mkdocs.en.yml" | ||||
|   "postCreateCommand": "git submodule init; git submodule update theme/assets/brand; ./run.sh --cmd=mkdocs --insiders --production --cmd_flags=--dev-addr=0.0.0.0:8000" | ||||
| } | ||||
|   | ||||
							
								
								
									
										63
									
								
								.github/CODEOWNERS
									
									
									
									
										vendored
									
									
								
							
							
						
						| @@ -1,15 +1,66 @@ | ||||
| # High-traffic pages | ||||
| /docs/index.md @jonaharagon @dngray | ||||
| /theme/overrides/ @jonaharagon | ||||
|  | ||||
| # Org | ||||
|  | ||||
| /docs/about/ @jonaharagon | ||||
| CODE_OF_CONDUCT.md @jonaharagon | ||||
| CITATION.cff | ||||
| LICENSE @jonaharagon | ||||
| CITATION.cff @jonaharagon | ||||
| LICENSE @jonaharagon @dngray | ||||
| LICENSE-CODE @jonaharagon | ||||
| README.md @jonaharagon @dngray | ||||
|  | ||||
| # Config | ||||
|  | ||||
| /mkdocs.yml @jonaharagon | ||||
| /mkdocs.blog.yml @jonaharagon | ||||
| /crowdin.yml @jonaharagon | ||||
| /includes/ @jonaharagon | ||||
|  | ||||
| # Ops | ||||
|  | ||||
| Dockerfile @jonaharagon | ||||
| /Pipfile @jonaharagon | ||||
| /Pipfile.lock @jonaharagon | ||||
| /.github/ @jonaharagon | ||||
| /run.sh @jonaharagon | ||||
| /modules/ @jonaharagon | ||||
|  | ||||
| # High-traffic pages | ||||
|  | ||||
| /blog/index.md @jonaharagon @freddy-m | ||||
| /docs/index.md @jonaharagon @dngray | ||||
| /theme/home.html @jonaharagon @dngray | ||||
| /theme/main.html @jonaharagon | ||||
| /theme/blog-post.html @jonaharagon | ||||
| /theme/partials/ @jonaharagon | ||||
| /theme/layouts/ @jonaharagon | ||||
|  | ||||
| # Financial-Related | ||||
|  | ||||
| /docs/about/donate.md @jonaharagon @SamsungGalaxyPlayer | ||||
| /docs/cryptocurrency.md @jonaharagon @SamsungGalaxyPlayer | ||||
| /docs/financial-services.md @jonaharagon @SamsungGalaxyPlayer | ||||
| /docs/advanced/payments.md @jonaharagon @SamsungGalaxyPlayer | ||||
|  | ||||
| # Blog authors | ||||
|  | ||||
| /blog/.authors.yml @jonaharagon @dngray @freddy-m | ||||
| /blog/author/ @jonaharagon @dngray @freddy-m | ||||
| /blog/author/dngray.md @dngray | ||||
| /blog/author/freddy.md @freddy-m | ||||
| /blog/author/jonah.md @jonaharagon | ||||
| /blog/author/niek-de-wilde.md @blacklight447 | ||||
|  | ||||
| # Blog posts | ||||
|  | ||||
| /blog/posts/ @jonaharagon | ||||
| /blog/posts/firefox-privacy-2021-update.md @dngray | ||||
| /blog/posts/firefox-privacy.md @jonaharagon | ||||
| /blog/posts/hide-nothing.md @freddy-m | ||||
| /blog/posts/macos-ventura-privacy-security-updates.md @jonaharagon | ||||
| /blog/posts/move-fast-and-break-things.md @freddy-m | ||||
| /blog/posts/mozilla-disappoints-us-yet-again-2.md @jonaharagon | ||||
| /blog/posts/privacy-guides-partners-with-magic-grants-501-c-3.md @jonaharagon | ||||
| /blog/posts/proton-wallet-review.md @jonaharagon | ||||
| /blog/posts/restrict-act.md @jonaharagon | ||||
| /blog/posts/the-trouble-with-vpn-and-privacy-review-sites.md @jonaharagon | ||||
| /blog/posts/virtual-insanity.md @freddy-m | ||||
| /blog/posts/welcome-to-privacy-guides.md @jonaharagon | ||||
|   | ||||
							
								
								
									
										18
									
								
								.github/PULL_REQUEST_TEMPLATE.md
									
									
									
									
										vendored
									
									
								
							
							
						
						| @@ -1,24 +1,14 @@ | ||||
| Changes proposed in this PR: | ||||
| List of changes proposed in this PR: | ||||
|  | ||||
| - | ||||
|  | ||||
| <!-- SCROLL TO BOTTOM TO AGREE!: | ||||
| <!-- | ||||
| Please use a descriptive title for your PR, it will be included in our changelog! | ||||
|  | ||||
| If you are making changes that you have a conflict of interest with, please | ||||
| If you are making changes that you have a conflict of interest with, you MUST | ||||
| disclose this as well (this does not disqualify your PR by any means): | ||||
|  | ||||
| Conflict of interest contributions involve contributing about yourself, | ||||
| family, friends, clients, employers, or your financial and other relationships. | ||||
| Any external relationship can trigger a conflict of interest. | ||||
| ANY external relationship can trigger a conflict of interest. | ||||
| --> | ||||
|  | ||||
| <!-- Place an x in the boxes below, like: [x] --> | ||||
| - [ ] I have disclosed any relevant conflicts of interest in my post. | ||||
| - [ ] I agree to grant Privacy Guides a perpetual, worldwide, non-exclusive, transferable, royalty-free, irrevocable license with the right to sublicense such rights through multiple tiers of sublicensees, to reproduce, modify, display, perform, relicense, and distribute my contribution as part of this project. | ||||
| - [ ] I am the sole author of this work. <!-- Do not check this box if you are not --> | ||||
| - [ ] I agree to the [Community Code of Conduct](https://www.privacyguides.org/coc). | ||||
|  | ||||
| <!-- What's this? When you submit a PR, you keep the Copyright for the work you | ||||
| are contributing. We need you to agree to the above terms in order for us to | ||||
| publish this contribution to our website. --> | ||||
|   | ||||
							
								
								
									
										77
									
								
								.github/dependabot.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						| @@ -1,77 +0,0 @@ | ||||
| # Copyright (c) 2021-2023 Jonah Aragon <jonah@triplebit.net> | ||||
|  | ||||
| # Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
| # of this software and associated documentation files (the "Software"), to | ||||
| # deal in the Software without restriction, including without limitation the | ||||
| # rights to use, copy, modify, merge, publish, distribute, sublicense, and/or | ||||
| # sell copies of the Software, and to permit persons to whom the Software is | ||||
| # furnished to do so, subject to the following conditions: | ||||
|  | ||||
| # The above copyright notice and this permission notice shall be included in | ||||
| # all copies or substantial portions of the Software. | ||||
|  | ||||
| # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
| # IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
| # FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT. IN NO EVENT SHALL THE | ||||
| # AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
| # LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING | ||||
| # FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS | ||||
| # IN THE SOFTWARE. | ||||
|  | ||||
| version: 2 | ||||
|  | ||||
| registries: | ||||
|   github-privacyguides: | ||||
|     type: git | ||||
|     url: https://github.com | ||||
|     username: x-access-token | ||||
|     password: ${{secrets.REPO_PAT}} | ||||
|  | ||||
| updates: | ||||
|   # Maintain dependencies for GitHub Actions | ||||
|   - package-ecosystem: "github-actions" | ||||
|     directory: "/" | ||||
|     schedule: | ||||
|       interval: "monthly" | ||||
|     assignees: | ||||
|       - "jonaharagon" | ||||
|     reviewers: | ||||
|       - "jonaharagon" | ||||
|     labels: | ||||
|       - "fix:github_actions" | ||||
|  | ||||
|   # Maintain submodules | ||||
|   - package-ecosystem: "gitsubmodule" | ||||
|     directory: "/" | ||||
|     registries: | ||||
|       - github-privacyguides | ||||
|     schedule: | ||||
|       interval: "monthly" | ||||
|     labels: | ||||
|       - "fix:submodules" | ||||
|  | ||||
|   - package-ecosystem: "devcontainers" | ||||
|     directory: "/" | ||||
|     schedule: | ||||
|       interval: weekly | ||||
|  | ||||
|   - package-ecosystem: "docker" | ||||
|     directory: "/" | ||||
|     schedule: | ||||
|       interval: weekly | ||||
| # Disabled because some updates tend to remove needed dependencies for some reason | ||||
|  | ||||
| #  # Maintain dependencies for pipenv | ||||
| #  - package-ecosystem: "pip" | ||||
| #    directory: "/" | ||||
| #    insecure-external-code-execution: allow | ||||
| #    registries: | ||||
| #      - github-privacyguides | ||||
| #    schedule: | ||||
| #      interval: "daily" | ||||
| #    assignees: | ||||
| #      - "jonaharagon" | ||||
| #    reviewers: | ||||
| #      - "jonaharagon" | ||||
| #    labels: | ||||
| #      - "fix:python" | ||||
							
								
								
									
										104
									
								
								.github/workflows/build-blog.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,104 @@ | ||||
| name: 🛠️ Build Blog | ||||
|  | ||||
| on: | ||||
|   workflow_call: | ||||
|     inputs: | ||||
|       ref: | ||||
|         required: true | ||||
|         type: string | ||||
|       repo: | ||||
|         required: true | ||||
|         type: string | ||||
|       context: | ||||
|         type: string | ||||
|         default: deploy-preview | ||||
|       continue-on-error: | ||||
|         type: boolean | ||||
|         default: true | ||||
|       privileged: | ||||
|         type: boolean | ||||
|         default: true | ||||
|  | ||||
| permissions: | ||||
|   contents: read | ||||
|  | ||||
| jobs: | ||||
|   build: | ||||
|     runs-on: ubuntu-latest | ||||
|     continue-on-error: ${{ inputs.continue-on-error }} | ||||
|     permissions: | ||||
|       contents: read | ||||
|  | ||||
|     steps: | ||||
|       - name: Add GitHub Token to Environment | ||||
|         run: | | ||||
|           echo "GH_TOKEN=${{ secrets.GITHUB_TOKEN }}" >> "$GITHUB_ENV" | ||||
|  | ||||
|       - name: Download Repository | ||||
|         uses: actions/checkout@v4 | ||||
|         with: | ||||
|           repository: ${{ inputs.repo }} | ||||
|           ref: ${{ inputs.ref }} | ||||
|           persist-credentials: "false" | ||||
|           fetch-depth: 0 | ||||
|  | ||||
|       - name: Download Submodules | ||||
|         uses: actions/download-artifact@v4 | ||||
|         with: | ||||
|           pattern: repo-* | ||||
|           path: modules | ||||
|  | ||||
|       - name: Move mkdocs-material-insiders to mkdocs-material | ||||
|         if: inputs.privileged | ||||
|         run: | | ||||
|           rmdir modules/mkdocs-material | ||||
|           mv modules/repo-mkdocs-material-insiders modules/mkdocs-material | ||||
|  | ||||
|       - name: Move brand submodule to theme/assets/brand | ||||
|         run: | | ||||
|           rmdir theme/assets/brand | ||||
|           mv modules/repo-brand theme/assets/brand | ||||
|  | ||||
|       - name: Install Python (pipenv) | ||||
|         if: inputs.privileged | ||||
|         uses: actions/setup-python@v5 | ||||
|         with: | ||||
|           cache: "pipenv" | ||||
|  | ||||
|       - name: Install Python (no pipenv) | ||||
|         if: ${{ !inputs.privileged }} | ||||
|         uses: actions/setup-python@v5 | ||||
|  | ||||
|       - name: Install Python Dependencies | ||||
|         if: inputs.privileged | ||||
|         run: | | ||||
|           pip install pipenv | ||||
|           pipenv install | ||||
|           sudo apt install pngquant | ||||
|  | ||||
|       - name: Install Python Dependencies (Unprivileged) | ||||
|         if: ${{ !inputs.privileged }} | ||||
|         run: | | ||||
|           pip install mkdocs-material mkdocs-rss-plugin mkdocs-glightbox mkdocs-macros-plugin | ||||
|           sudo apt install pngquant | ||||
|  | ||||
|       - name: Build Website (Privileged) | ||||
|         if: inputs.privileged | ||||
|         run: | | ||||
|           pipenv run mkdocs build --config-file mkdocs.blog.yml | ||||
|  | ||||
|       - name: Build Website (Unprivileged) | ||||
|         if: ${{ !inputs.privileged }} | ||||
|         run: | | ||||
|           BUILD_INSIDERS=false mkdocs build --config-file mkdocs.blog.yml | ||||
|  | ||||
|       - name: Package Website | ||||
|         run: | | ||||
|           tar -czf site-build-blog.tar.gz site | ||||
|  | ||||
|       - name: Upload Site | ||||
|         uses: actions/upload-artifact@v4 | ||||
|         with: | ||||
|           name: site-build-blog.tar.gz | ||||
|           path: site-build-blog.tar.gz | ||||
|           retention-days: 1 | ||||
							
								
								
									
										5
									
								
								.github/workflows/build-container.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						| @@ -1,4 +1,3 @@ | ||||
| # | ||||
| name: ☁️ Build Container | ||||
|  | ||||
| # Configures this workflow to run every time a change is pushed to the branch called `release`. | ||||
| @@ -56,7 +55,7 @@ jobs: | ||||
|  | ||||
|       # Uses the `docker/login-action` action to log in to the Container registry registry using the account and password that will publish the packages. Once published, the packages are scoped to the account defined here. | ||||
|       - name: Log in to the Container registry | ||||
|         uses: docker/login-action@v3.1.0 | ||||
|         uses: docker/login-action@v3.3.0 | ||||
|         with: | ||||
|           registry: ${{ env.REGISTRY }} | ||||
|           username: ${{ github.actor }} | ||||
| @@ -80,7 +79,7 @@ jobs: | ||||
|       # It uses the `context` parameter to define the build's context as the set of files located in the specified path. For more information, see "[Usage](https://github.com/docker/build-push-action#usage)" in the README of the `docker/build-push-action` repository. | ||||
|       # It uses the `tags` and `labels` parameters to tag and label the image with the output from the "meta" step. | ||||
|       - name: Build and push Docker image | ||||
|         uses: docker/build-push-action@v5.3.0 | ||||
|         uses: docker/build-push-action@v6.9.0 | ||||
|         with: | ||||
|           context: . | ||||
|           push: true | ||||
|   | ||||
							
								
								
									
										131
									
								
								.github/workflows/build-pr.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,131 @@ | ||||
| name: 🛠️ Build PR Preview | ||||
|  | ||||
| on: | ||||
|   pull_request: | ||||
|  | ||||
| concurrency: | ||||
|   group: ${{github.event.pull_request.head.ref}} | ||||
|   cancel-in-progress: true | ||||
|  | ||||
| permissions: | ||||
|   contents: read | ||||
|  | ||||
| jobs: | ||||
|   metadata: | ||||
|     runs-on: ubuntu-latest | ||||
|     outputs: | ||||
|       submodules: ${{ steps.submodules-fork.outputs.submodules || steps.submodules-main.outputs.submodules }} | ||||
|       privileged: ${{ steps.submodules-fork.outputs.privileged || steps.submodules-main.outputs.privileged }} | ||||
|     env: | ||||
|       ACTIONS_SSH_KEY: ${{ secrets.ACTIONS_SSH_KEY }} | ||||
|     steps: | ||||
|       - name: Save PR metadata | ||||
|         run: | | ||||
|           mkdir -p ./metadata | ||||
|           echo ${{ github.event.number }} > ./metadata/NR | ||||
|           echo ${{ github.event.pull_request.head.sha }} > ./metadata/SHA | ||||
|  | ||||
|       - name: Set submodules for fork | ||||
|         if: env.ACTIONS_SSH_KEY == '' | ||||
|         id: submodules-fork | ||||
|         run: | | ||||
|           echo 'submodules={"repo":["brand","i18n"]}' >> "$GITHUB_OUTPUT" | ||||
|           echo "privileged=false" >> "$GITHUB_OUTPUT" | ||||
|           echo "false" > ./metadata/PRIVILEGED | ||||
|  | ||||
|       - name: Set submodules for main repo | ||||
|         if: env.ACTIONS_SSH_KEY != '' | ||||
|         id: submodules-main | ||||
|         run: | | ||||
|           echo 'submodules={"repo":["brand","i18n","mkdocs-material-insiders"]}' >> "$GITHUB_OUTPUT" | ||||
|           echo "privileged=true" >> "$GITHUB_OUTPUT" | ||||
|           echo "true" > ./metadata/PRIVILEGED | ||||
|  | ||||
|       - name: Upload metadata as artifact | ||||
|         uses: actions/upload-artifact@v4 | ||||
|         with: | ||||
|           name: metadata | ||||
|           path: metadata | ||||
|  | ||||
|   submodule: | ||||
|     needs: metadata | ||||
|     strategy: | ||||
|       matrix: ${{ fromJson(needs.metadata.outputs.submodules) }} | ||||
|     uses: privacyguides/.github/.github/workflows/download-repo.yml@main | ||||
|     with: | ||||
|       repo: ${{ matrix.repo }} | ||||
|       privileged: ${{ fromJSON(needs.metadata.outputs.privileged) }} | ||||
|     secrets: | ||||
|       ACTIONS_SSH_KEY: ${{ secrets.ACTIONS_SSH_KEY }} | ||||
|  | ||||
|   build_english: | ||||
|     needs: [submodule, metadata] | ||||
|     strategy: | ||||
|       matrix: | ||||
|         lang: [en] | ||||
|       fail-fast: true | ||||
|     uses: ./.github/workflows/build.yml | ||||
|     with: | ||||
|       ref: ${{github.event.pull_request.head.ref}} | ||||
|       repo: ${{github.event.pull_request.head.repo.full_name}} | ||||
|       lang: en | ||||
|       continue-on-error: false | ||||
|       privileged: ${{ fromJSON(needs.metadata.outputs.privileged) }} | ||||
|       strict: true | ||||
|  | ||||
|   build_i18n: | ||||
|     if: ${{ contains(github.event.pull_request.labels.*.name, 'ci:build i18n') }} | ||||
|     needs: [submodule, metadata] | ||||
|     strategy: | ||||
|       matrix: | ||||
|         lang: [es, fr, he, it, nl, ru, zh-Hant] | ||||
|       fail-fast: false | ||||
|     uses: ./.github/workflows/build.yml | ||||
|     with: | ||||
|       ref: ${{github.event.pull_request.head.ref}} | ||||
|       repo: ${{github.event.pull_request.head.repo.full_name}} | ||||
|       lang: ${{ matrix.lang }} | ||||
|       continue-on-error: true | ||||
|       privileged: ${{ fromJSON(needs.metadata.outputs.privileged) }} | ||||
|       strict: true | ||||
|  | ||||
|   build_blog: | ||||
|     if: ${{ contains(github.event.pull_request.labels.*.name, 'ci:build blog') }} | ||||
|     needs: [submodule, metadata] | ||||
|     uses: ./.github/workflows/build-blog.yml | ||||
|     with: | ||||
|       ref: ${{github.event.pull_request.head.ref}} | ||||
|       repo: ${{github.event.pull_request.head.repo.full_name}} | ||||
|       continue-on-error: true | ||||
|       privileged: ${{ fromJSON(needs.metadata.outputs.privileged) }} | ||||
|  | ||||
|   combine_build: | ||||
|     needs: [build_english, build_i18n, build_blog] | ||||
|     if: | | ||||
|       (always() && !cancelled() && !failure()) && | ||||
|       needs.build_english.result == 'success' && | ||||
|       (needs.build_i18n.result == 'success' || needs.build_i18n.result == 'skipped') && | ||||
|       (needs.build_blog.result == 'success' || needs.build_blog.result == 'skipped') | ||||
|  | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|       - uses: actions/download-artifact@v4 | ||||
|         with: | ||||
|           pattern: site-build-* | ||||
|           merge-multiple: true | ||||
|  | ||||
|       - run: | | ||||
|           for file in *.tar.gz; do tar -zxf "$file"; done | ||||
|           ls -la site/ | ||||
|  | ||||
|       - name: Upload Site | ||||
|         uses: actions/upload-artifact@v4 | ||||
|         with: | ||||
|           name: site-build-combined | ||||
|           path: site | ||||
|           retention-days: 5 | ||||
|  | ||||
|   cleanup: | ||||
|     if: ${{ always() }} | ||||
|     needs: [build_english, build_i18n, build_blog] | ||||
|     uses: privacyguides/.github/.github/workflows/cleanup.yml@main | ||||
							
								
								
									
										233
									
								
								.github/workflows/build.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						| @@ -1,4 +1,4 @@ | ||||
| name: Build Website | ||||
| name: 🛠️ Build Website | ||||
|  | ||||
| on: | ||||
|   workflow_call: | ||||
| @@ -21,6 +21,15 @@ on: | ||||
|       continue-on-error: | ||||
|         type: boolean | ||||
|         default: true | ||||
|       privileged: | ||||
|         type: boolean | ||||
|         default: true | ||||
|       strict: | ||||
|         type: boolean | ||||
|         default: false | ||||
|       cache: | ||||
|         type: boolean | ||||
|         default: true | ||||
|  | ||||
| permissions: | ||||
|   contents: read | ||||
| @@ -33,104 +42,222 @@ jobs: | ||||
|       contents: read | ||||
|  | ||||
|     steps: | ||||
|       - run: | | ||||
|       - name: Add GitHub Token to Environment | ||||
|         run: | | ||||
|           echo "GH_TOKEN=${{ secrets.GITHUB_TOKEN }}" >> "$GITHUB_ENV" | ||||
|  | ||||
|       - if: inputs.config == 'build' | ||||
|       - name: Set Metadata | ||||
|         if: inputs.config == 'build' | ||||
|         run: | | ||||
|           { | ||||
|             echo "MKDOCS_INHERIT=mkdocs-production.yml" | ||||
|             echo "PRODUCTION=true" | ||||
|             echo "CONTEXT=${{ inputs.context }}" | ||||
|             echo "BUILD_CONTEXT=${{ inputs.context }}" | ||||
|             echo "EXTRA_FLAGS=""$EXTRA_FLAGS" --production"" | ||||
|           } >> "$GITHUB_ENV" | ||||
|  | ||||
|       - if: inputs.config == 'offline' | ||||
|       - name: Set Metadata for Privileged Builds | ||||
|         if: inputs.privileged | ||||
|         run: | | ||||
|           echo "MKDOCS_INHERIT=mkdocs-offline.yml" >> "$GITHUB_ENV" | ||||
|           echo "CARDS=false" >> "$GITHUB_ENV" | ||||
|           echo "BUILD_INSIDERS=true" >> "$GITHUB_ENV" | ||||
|           echo "EXTRA_FLAGS=""$EXTRA_FLAGS" --insiders"" >> "$GITHUB_ENV" | ||||
|  | ||||
|       - uses: actions/checkout@v4 | ||||
|       - name: Set Metadata for International Builds | ||||
|         if: inputs.lang != 'en' | ||||
|         run: | | ||||
|           echo "GITREVISIONDATE=false" >> "$GITHUB_ENV" | ||||
|           echo "GITAUTHORS=false" >> "$GITHUB_ENV" | ||||
|  | ||||
|       - name: Set Metadata for Offline Mode | ||||
|         if: inputs.config == 'offline' | ||||
|         run: | | ||||
|           { | ||||
|             echo "EXTRA_FLAGS=""$EXTRA_FLAGS" --offline"" | ||||
|           } >> "$GITHUB_ENV" | ||||
|  | ||||
|       - name: Set Metadata for Strict Mode | ||||
|         if: inputs.strict | ||||
|         run: | | ||||
|           echo "EXTRA_FLAGS=""$EXTRA_FLAGS" --cmd_flags=--strict"" >> "$GITHUB_ENV" | ||||
|  | ||||
|       - name: Download Repository | ||||
|         uses: actions/checkout@v4 | ||||
|         with: | ||||
|           repository: ${{ inputs.repo }} | ||||
|           ref: ${{ inputs.ref }} | ||||
|           persist-credentials: "false" | ||||
|           fetch-depth: 0 | ||||
|  | ||||
|       - uses: actions/download-artifact@v4 | ||||
|       - name: Download Submodules | ||||
|         uses: actions/download-artifact@v4 | ||||
|         with: | ||||
|           pattern: repo-* | ||||
|           path: modules | ||||
|  | ||||
|       - run: | | ||||
|       - name: Move mkdocs-material-insiders to mkdocs-material | ||||
|         if: inputs.privileged | ||||
|         run: | | ||||
|           rmdir modules/mkdocs-material | ||||
|           mv modules/repo-mkdocs-material-insiders modules/mkdocs-material | ||||
|  | ||||
|       - name: Move brand submodule to theme/assets/brand | ||||
|         run: | | ||||
|           rmdir theme/assets/brand | ||||
|           mv modules/repo-brand theme/assets/brand | ||||
|  | ||||
|       - if: inputs.lang != 'en' | ||||
|       - name: Copy Translation Files | ||||
|         if: inputs.lang != 'en' | ||||
|         run: | | ||||
|           cp -rl modules/repo-i18n/i18n . | ||||
|           cp -rl modules/repo-i18n/includes . | ||||
|           cp -rl modules/repo-i18n/theme . | ||||
|  | ||||
|       - uses: actions/setup-python@v5 | ||||
|       - name: Install Python (pipenv) | ||||
|         if: inputs.privileged | ||||
|         uses: actions/setup-python@v5 | ||||
|         with: | ||||
|           cache: "pipenv" | ||||
|  | ||||
|       - uses: actions/cache/restore@v4.0.2 | ||||
|         id: site_cache_restore | ||||
|         with: | ||||
|           key: site-cache-${{ inputs.repo }}-${{ inputs.ref }}-${{ hashfiles('.cache/**') }} | ||||
|           path: .cache | ||||
|           restore-keys: | | ||||
|             site-cache-${{ inputs.repo }}-${{ inputs.ref }}- | ||||
|             site-cache-${{ inputs.repo }}- | ||||
|       - name: Install Python (no pipenv) | ||||
|         if: ${{ !inputs.privileged }} | ||||
|         uses: actions/setup-python@v5 | ||||
|  | ||||
|       - uses: actions/cache/restore@v4.0.2 | ||||
|         id: card_cache_restore | ||||
|       - name: Restore Privacy Plugin Cache | ||||
|         uses: actions/cache/restore@v4.0.2 | ||||
|         id: privacy_cache_restore | ||||
|         if: inputs.cache | ||||
|         with: | ||||
|           key: card-cache-${{ inputs.repo }}-${{ inputs.lang }}-${{ inputs.ref }}-${{ hashfiles('config/.cache/plugin/social/manifest.json') }} | ||||
|           key: privacy-cache-${{ inputs.repo }}-${{ hashfiles('.cache/plugin/privacy/**') }} | ||||
|           path: | | ||||
|             config/.cache/plugin/social/manifest.json | ||||
|             config/.cache/plugin/social/assets | ||||
|             .cache/plugin/privacy | ||||
|           restore-keys: | | ||||
|             card-cache-${{ inputs.repo }}-${{ inputs.lang }}-${{ inputs.ref }}- | ||||
|             card-cache-${{ inputs.repo }}-${{ inputs.lang }}- | ||||
|             privacy-cache-${{ inputs.repo }}- | ||||
|             privacy-cache-privacyguides/privacyguides.org- | ||||
|             privacy-cache- | ||||
|  | ||||
|       - run: | | ||||
|       - name: Restore Social Plugin Cache | ||||
|         uses: actions/cache/restore@v4.0.2 | ||||
|         id: social_cache_restore | ||||
|         if: inputs.cache | ||||
|         with: | ||||
|           key: social-cache-${{ inputs.repo }}-${{ inputs.lang }}-${{ hashfiles('.cache/plugin/social/manifest.json') }} | ||||
|           path: | | ||||
|             .cache/plugin/social/manifest.json | ||||
|             .cache/plugin/social/assets | ||||
|           restore-keys: | | ||||
|             social-cache-${{ inputs.repo }}-${{ inputs.lang }}- | ||||
|             social-cache-privacyguides/privacyguides.org-${{ inputs.lang }}- | ||||
|  | ||||
|       - name: Restore Optimize Plugin Cache | ||||
|         uses: actions/cache/restore@v4.0.2 | ||||
|         id: optimize_cache_restore | ||||
|         if: inputs.cache | ||||
|         with: | ||||
|           key: optimize-cache-${{ inputs.repo }}-${{ hashfiles('.cache/plugin/optimize/manifest.json') }} | ||||
|           path: | | ||||
|             .cache/plugin/optimize | ||||
|           restore-keys: | | ||||
|             optimize-cache-${{ inputs.repo }}- | ||||
|             optimize-cache-privacyguides/privacyguides.org- | ||||
|             optimize-cache- | ||||
|  | ||||
|       - name: Install Python Dependencies | ||||
|         if: inputs.privileged | ||||
|         run: | | ||||
|           pip install pipenv | ||||
|           pipenv install | ||||
|           sudo apt install pngquant | ||||
|  | ||||
|       - uses: falti/dotenv-action@v1.1 | ||||
|         with: | ||||
|           path: includes/strings.${{ inputs.lang }}.env | ||||
|           export-variables: true | ||||
|           keys-case: bypass | ||||
|       - name: Install Python Dependencies (Unprivileged) | ||||
|         if: ${{ !inputs.privileged }} | ||||
|         run: | | ||||
|           pip install mkdocs-material | ||||
|           sudo apt install pngquant | ||||
|           echo "EXTRA_FLAGS=""$EXTRA_FLAGS" --cmd=mkdocs"" >> "$GITHUB_ENV" | ||||
|  | ||||
|       - run: | | ||||
|           pipenv run mkdocs build --config-file config/mkdocs.${{ inputs.lang }}.yml | ||||
|           pipenv run mkdocs --version | ||||
|           tar -czvf site-${{ inputs.config }}-${{ inputs.lang }}.tar.gz site | ||||
|       - name: Build Website | ||||
|         run: | | ||||
|           eval ./run.sh --build --lang=${{ inputs.lang }} "$EXTRA_FLAGS" | ||||
|  | ||||
|       - uses: actions/cache/save@v4.0.2 | ||||
|         if: steps.site_cache_restore.outputs.cache-hit != 'true' | ||||
|         with: | ||||
|           key: site-cache-${{ inputs.repo }}-${{ inputs.ref }}-${{ hashfiles('.cache/**') }} | ||||
|           path: .cache | ||||
|       - name: Run index-generation.sh for top posts | ||||
|         if: inputs.lang == 'en' | ||||
|         run: | | ||||
|           bash index-generation.sh \ | ||||
|             --source='https://discuss.privacyguides.net/top.json?period=weekly' \ | ||||
|             --tag="top posts" \ | ||||
|             --destination="./site/en/index.html" \ | ||||
|             --count=3 | ||||
|  | ||||
|       - uses: actions/cache/save@v4.0.2 | ||||
|         if: steps.card_cache_restore.outputs.cache-hit != 'true' | ||||
|       - name: Run index-generation.sh for latest posts | ||||
|         if: inputs.lang == 'en' | ||||
|         run: | | ||||
|           bash index-generation.sh \ | ||||
|             --source='https://discuss.privacyguides.net/latest.json' \ | ||||
|             --tag="latest posts" \ | ||||
|             --destination="./site/en/index.html" \ | ||||
|             --count=12 | ||||
|  | ||||
|       - name: Package Website | ||||
|         run: | | ||||
|           tar -czf site-${{ inputs.config }}-${{ inputs.lang }}.tar.gz site | ||||
|  | ||||
|       - name: Find Privacy Plugin Cache | ||||
|         uses: actions/cache/restore@v4.0.2 | ||||
|         if: steps.privacy_cache_restore.outputs.cache-hit != 'true' && inputs.cache | ||||
|         id: privacy_cache_test | ||||
|         with: | ||||
|           key: card-cache-${{ inputs.repo }}-${{ inputs.lang }}-${{ inputs.ref }}-${{ hashfiles('config/.cache/plugin/social/manifest.json') }} | ||||
|           key: privacy-cache-privacyguides/privacyguides.org-${{ hashfiles('.cache/plugin/privacy/**') }} | ||||
|           lookup-only: true | ||||
|           path: | | ||||
|             config/.cache/plugin/social/manifest.json | ||||
|             config/.cache/plugin/social/assets | ||||
|             .cache/plugin/privacy | ||||
|  | ||||
|       - uses: actions/upload-artifact@v4 | ||||
|       - name: Find Social Plugin Cache | ||||
|         uses: actions/cache/restore@v4.0.2 | ||||
|         if: steps.social_cache_restore.outputs.cache-hit != 'true' && inputs.cache | ||||
|         id: social_cache_test | ||||
|         with: | ||||
|           key: social-cache-privacyguides/privacyguides.org-${{ inputs.lang }}-${{ hashfiles('.cache/plugin/social/manifest.json') }} | ||||
|           lookup-only: true | ||||
|           path: | | ||||
|             .cache/plugin/social/manifest.json | ||||
|             .cache/plugin/social/assets | ||||
|  | ||||
|       - name: Find Optimize Plugin Cache | ||||
|         uses: actions/cache/restore@v4.0.2 | ||||
|         if: steps.optimize_cache_restore.outputs.cache-hit != 'true' && inputs.cache | ||||
|         id: optimize_cache_test | ||||
|         with: | ||||
|           key: optimize-cache-privacyguides/privacyguides.org-${{ hashfiles('.cache/plugin/optimize/manifest.json') }} | ||||
|           lookup-only: true | ||||
|           path: | | ||||
|             .cache/plugin/optimize | ||||
|  | ||||
|       - name: Save Privacy Plugin Cache | ||||
|         uses: actions/cache/save@v4.0.2 | ||||
|         if: steps.privacy_cache_test.outputs.cache-hit != 'true' && inputs.cache | ||||
|         with: | ||||
|           key: privacy-cache-${{ inputs.repo }}-${{ hashfiles('.cache/plugin/privacy/**') }} | ||||
|           path: .cache/plugin/privacy | ||||
|  | ||||
|       - name: Save Social Plugin Cache | ||||
|         uses: actions/cache/save@v4.0.2 | ||||
|         if: steps.social_cache_test.outputs.cache-hit != 'true' && inputs.cache | ||||
|         with: | ||||
|           key: social-cache-${{ inputs.repo }}-${{ inputs.lang }}-${{ hashfiles('.cache/plugin/social/manifest.json') }} | ||||
|           path: | | ||||
|             .cache/plugin/social/manifest.json | ||||
|             .cache/plugin/social/assets | ||||
|  | ||||
|       - name: Save Optimize Plugin Cache | ||||
|         uses: actions/cache/save@v4.0.2 | ||||
|         if: steps.optimize_cache_test.outputs.cache-hit != 'true' && inputs.cache | ||||
|         with: | ||||
|           key: optimize-cache-${{ inputs.repo }}-${{ hashfiles('.cache/plugin/optimize/manifest.json') }} | ||||
|           path: .cache/plugin/optimize | ||||
|  | ||||
|       - name: Upload Site | ||||
|         uses: actions/upload-artifact@v4 | ||||
|         with: | ||||
|           name: site-${{ inputs.config }}-${{ inputs.lang }}.tar.gz | ||||
|           path: site-${{ inputs.config }}-${{ inputs.lang }}.tar.gz | ||||
|           retention-days: 1 | ||||
|  | ||||
|   offline_package: | ||||
|     if: inputs.config == 'offline' && inputs.lang == 'en' | ||||
| @@ -146,8 +273,8 @@ jobs: | ||||
|           name: site-offline-en.tar.gz | ||||
|  | ||||
|       - run: | | ||||
|           tar -xzvf site-offline-en.tar.gz | ||||
|           tar -czvf offline.tar.gz site/en | ||||
|           tar -xzf site-offline-en.tar.gz | ||||
|           tar -czf offline.tar.gz site/en | ||||
|           zip -r -q offline.zip site/en | ||||
|  | ||||
|       - name: Upload tar.gz file | ||||
|   | ||||
							
								
								
									
										11
									
								
								.github/workflows/publish-mirror.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						| @@ -51,14 +51,3 @@ jobs: | ||||
|         with: | ||||
|           source-repo: "git@github.com:privacyguides/privacyguides.org.git" | ||||
|           destination-repo: "git@codeberg.org:privacyguides/privacyguides.org.git" | ||||
|  | ||||
|   sourcehut: | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|       - name: Mirror to SourceHut | ||||
|         uses: wearerequired/git-mirror-action@v1 | ||||
|         env: | ||||
|           SSH_PRIVATE_KEY: ${{ secrets.ACTIONS_SSH_KEY }} | ||||
|         with: | ||||
|           source-repo: "git@github.com:privacyguides/privacyguides.org.git" | ||||
|           destination-repo: "git@git.sr.ht:~jonaharagon/privacyguides.org" | ||||
|   | ||||
							
								
								
									
										187
									
								
								.github/workflows/publish-pr.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						| @@ -1,103 +1,152 @@ | ||||
| # Copyright (c) 2024 Jonah Aragon <jonah@triplebit.net> | ||||
|  | ||||
| # Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
| # of this software and associated documentation files (the "Software"), to | ||||
| # deal in the Software without restriction, including without limitation the | ||||
| # rights to use, copy, modify, merge, publish, distribute, sublicense, and/or | ||||
| # sell copies of the Software, and to permit persons to whom the Software is | ||||
| # furnished to do so, subject to the following conditions: | ||||
|  | ||||
| # The above copyright notice and this permission notice shall be included in | ||||
| # all copies or substantial portions of the Software. | ||||
|  | ||||
| # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
| # IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
| # FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT. IN NO EVENT SHALL THE | ||||
| # AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
| # LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING | ||||
| # FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS | ||||
| # IN THE SOFTWARE. | ||||
|  | ||||
| name: 📦 PR Preview | ||||
|  | ||||
| on: | ||||
|   pull_request_target: | ||||
|  | ||||
| concurrency: | ||||
|   group: ${{github.event.pull_request.head.ref}} | ||||
|   cancel-in-progress: true | ||||
|   workflow_run: | ||||
|     workflows: [🛠️ Build PR Preview] | ||||
|     types: | ||||
|       - completed | ||||
|  | ||||
| permissions: | ||||
|   pull-requests: write | ||||
|   actions: read | ||||
|   contents: read | ||||
|   pull-requests: write | ||||
|  | ||||
| jobs: | ||||
|   submodule: | ||||
|     strategy: | ||||
|       matrix: | ||||
|         repo: | ||||
|           - name: mkdocs-material-insiders | ||||
|             ref: main | ||||
|           - name: brand | ||||
|             ref: main | ||||
|           - name: i18n | ||||
|             ref: main | ||||
|     uses: privacyguides/.github/.github/workflows/download-repo.yml@main | ||||
|     with: | ||||
|       repo: ${{ matrix.repo.name }} | ||||
|     secrets: | ||||
|       ACTIONS_SSH_KEY: ${{ secrets.ACTIONS_SSH_KEY }} | ||||
|   metadata: | ||||
|     if: > | ||||
|       github.event.workflow_run.event == 'pull_request' && | ||||
|       github.event.workflow_run.conclusion == 'success' | ||||
|  | ||||
|   build: | ||||
|     needs: submodule | ||||
|     strategy: | ||||
|       matrix: | ||||
|         lang: [es, fr, he, it, nl, ru, zh-Hant] | ||||
|         allow-error: [true] | ||||
|         include: | ||||
|           - lang: en | ||||
|             allow-error: false | ||||
|       fail-fast: false | ||||
|     runs-on: ubuntu-latest | ||||
|  | ||||
|     outputs: | ||||
|       pr_number: ${{ steps.metadata.outputs.pr_number }} | ||||
|       sha: ${{ steps.metadata.outputs.sha }} | ||||
|       privileged: ${{ steps.metadata.outputs.privileged }} | ||||
|  | ||||
|     steps: | ||||
|       - name: Download Website Build Artifact | ||||
|         uses: actions/github-script@v7.0.1 | ||||
|         with: | ||||
|           script: | | ||||
|             var artifacts = await github.rest.actions.listWorkflowRunArtifacts({ | ||||
|                owner: context.repo.owner, | ||||
|                repo: context.repo.repo, | ||||
|                run_id: ${{github.event.workflow_run.id }}, | ||||
|             }); | ||||
|             var matchArtifact = artifacts.data.artifacts.filter((artifact) => { | ||||
|               return artifact.name == "site-build-combined" | ||||
|             })[0]; | ||||
|             var download = await github.rest.actions.downloadArtifact({ | ||||
|                owner: context.repo.owner, | ||||
|                repo: context.repo.repo, | ||||
|                artifact_id: matchArtifact.id, | ||||
|                archive_format: 'zip', | ||||
|             }); | ||||
|             var fs = require('fs'); | ||||
|             fs.writeFileSync('${{github.workspace}}/site-build-combined.zip', Buffer.from(download.data)); | ||||
|  | ||||
|       - name: Unpack Website | ||||
|         run: | | ||||
|           mkdir -p site | ||||
|           unzip site-build-combined.zip -d site | ||||
|           tar -czvf site-build-combined.tar.gz site | ||||
|  | ||||
|       - name: Upload Combined Build Artifact | ||||
|         uses: actions/upload-artifact@v4 | ||||
|         with: | ||||
|           name: site-build-combined.tar.gz | ||||
|           path: site-build-combined.tar.gz | ||||
|           retention-days: 5 | ||||
|  | ||||
|       - name: Download Metadata Artifact | ||||
|         uses: actions/github-script@v7.0.1 | ||||
|         with: | ||||
|           script: | | ||||
|             var artifacts = await github.rest.actions.listWorkflowRunArtifacts({ | ||||
|                owner: context.repo.owner, | ||||
|                repo: context.repo.repo, | ||||
|                run_id: ${{github.event.workflow_run.id }}, | ||||
|             }); | ||||
|             var matchArtifact = artifacts.data.artifacts.filter((artifact) => { | ||||
|               return artifact.name == "metadata" | ||||
|             })[0]; | ||||
|             var download = await github.rest.actions.downloadArtifact({ | ||||
|                owner: context.repo.owner, | ||||
|                repo: context.repo.repo, | ||||
|                artifact_id: matchArtifact.id, | ||||
|                archive_format: 'zip', | ||||
|             }); | ||||
|             var fs = require('fs'); | ||||
|             fs.writeFileSync('${{github.workspace}}/metadata.zip', Buffer.from(download.data)); | ||||
|  | ||||
|       - name: Set Metadata | ||||
|         id: metadata | ||||
|         run: | | ||||
|           mkdir -p metadata | ||||
|           unzip metadata.zip -d metadata | ||||
|           echo "pr_number=$(cat metadata/NR)" >> "$GITHUB_OUTPUT" | ||||
|           echo "sha=$(cat metadata/SHA)" >> "$GITHUB_OUTPUT" | ||||
|           echo "privileged=$(cat metadata/PRIVILEGED)" >> "$GITHUB_OUTPUT" | ||||
|  | ||||
|   deploy_netlify: | ||||
|     needs: metadata | ||||
|     permissions: | ||||
|       contents: read | ||||
|     uses: ./.github/workflows/build.yml | ||||
|     with: | ||||
|       ref: ${{github.event.pull_request.head.ref}} | ||||
|       repo: ${{github.event.pull_request.head.repo.full_name}} | ||||
|       lang: ${{ matrix.lang }} | ||||
|       continue-on-error: ${{ matrix.allow-error }} | ||||
|  | ||||
|   deploy: | ||||
|     needs: build | ||||
|     permissions: | ||||
|       contents: read | ||||
|     uses: privacyguides/webserver/.github/workflows/deploy-netlify-preview.yml@main | ||||
|     with: | ||||
|       netlify_alias: ${{ github.event.pull_request.head.sha }} | ||||
|       netlify_alias: ${{ needs.metadata.outputs.pr_number }} | ||||
|       netlify_site_id: ${{ vars.NETLIFY_SITE }} | ||||
|     secrets: | ||||
|       NETLIFY_TOKEN: ${{ secrets.NETLIFY_TOKEN }} | ||||
|  | ||||
|   deploy_garage: | ||||
|     needs: metadata | ||||
|     permissions: | ||||
|       contents: read | ||||
|  | ||||
|     uses: privacyguides/webserver/.github/workflows/deploy-garage-preview.yml@main | ||||
|     with: | ||||
|       alias: ${{ needs.metadata.outputs.pr_number }} | ||||
|       bucket: ${{ vars.PREVIEW_GARAGE_BUCKET }} | ||||
|       hostname: ${{ vars.PREVIEW_GARAGE_HOSTNAME }} | ||||
|     secrets: | ||||
|       PREVIEW_GARAGE_KEY_ID: ${{ secrets.PREVIEW_GARAGE_KEY_ID }} | ||||
|       PREVIEW_GARAGE_SECRET_KEY: ${{ secrets.PREVIEW_GARAGE_SECRET_KEY }} | ||||
|  | ||||
|   comment: | ||||
|     permissions: | ||||
|       pull-requests: write | ||||
|     needs: deploy | ||||
|     needs: [deploy_garage, metadata] | ||||
|     runs-on: ubuntu-latest | ||||
|     env: | ||||
|       address: ${{ needs.deploy.outputs.address }} | ||||
|       address: ${{ needs.deploy_garage.outputs.address }} | ||||
|     steps: | ||||
|       - uses: thollander/actions-comment-pull-request@v2.5.0 | ||||
|         if: ${{ needs.metadata.outputs.privileged == 'true' }} | ||||
|         with: | ||||
|           pr_number: ${{ needs.metadata.outputs.pr_number }} | ||||
|           message: | | ||||
|             ### <span aria-hidden="true">✅</span> Your preview is ready! | ||||
|  | ||||
|             |  Name | Link | | ||||
|             | :---: | ---- | | ||||
|             | <span aria-hidden="true">🔨</span> Latest commit | ${{ github.event.pull_request.head.sha }} | | ||||
|             | <span aria-hidden="true">🔨</span> Latest commit | ${{ needs.metadata.outputs.sha }} | | ||||
|             | <span aria-hidden="true">😎</span> Preview | ${{ env.address }} | | ||||
|           comment_tag: deployment | ||||
|  | ||||
|   cleanup: | ||||
|     if: ${{ always() }} | ||||
|     needs: build | ||||
|     uses: privacyguides/.github/.github/workflows/cleanup.yml@main | ||||
|       - uses: thollander/actions-comment-pull-request@v2.5.0 | ||||
|         if: ${{ needs.metadata.outputs.privileged == 'false' }} | ||||
|         with: | ||||
|           pr_number: ${{ needs.metadata.outputs.pr_number }} | ||||
|           message: | | ||||
|             ### <span aria-hidden="true">✅</span> Your preview is ready! | ||||
|  | ||||
|             |  Name | Link | | ||||
|             | :---: | ---- | | ||||
|             | <span aria-hidden="true">🔨</span> Latest commit | ${{ needs.metadata.outputs.sha }} | | ||||
|             | <span aria-hidden="true">😎</span> Preview | ${{ env.address }} | | ||||
|  | ||||
|             Please note that this preview was built from an untrusted source, so it was not granted access to all mkdocs-material features. Maintainers should ensure this PR has been reviewed locally with a full build before merging. | ||||
|           comment_tag: deployment | ||||
|   | ||||
							
								
								
									
										17
									
								
								.github/workflows/publish-release.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						| @@ -62,6 +62,17 @@ jobs: | ||||
|       lang: ${{ matrix.lang }} | ||||
|       context: production | ||||
|       continue-on-error: false | ||||
|       cache: false | ||||
|  | ||||
|   build_blog: | ||||
|     needs: submodule | ||||
|     permissions: | ||||
|       contents: read | ||||
|     uses: ./.github/workflows/build-blog.yml | ||||
|     with: | ||||
|       repo: ${{ github.repository }} | ||||
|       ref: ${{ github.ref }} | ||||
|       continue-on-error: false | ||||
|  | ||||
|   release: | ||||
|     name: Create release notes | ||||
| @@ -84,12 +95,14 @@ jobs: | ||||
|           makeLatest: true | ||||
|  | ||||
|   deploy: | ||||
|     needs: build | ||||
|     needs: [build, build_blog] | ||||
|     uses: privacyguides/webserver/.github/workflows/deploy-all.yml@main | ||||
|     secrets: | ||||
|       NETLIFY_TOKEN: ${{ secrets.NETLIFY_TOKEN }} | ||||
|       PROD_MINIO_KEY_ID: ${{ secrets.PROD_MINIO_KEY_ID }} | ||||
|       PROD_MINIO_SECRET_KEY: ${{ secrets.PROD_MINIO_SECRET_KEY }} | ||||
|       PROD_GARAGE_KEY_ID: ${{ secrets.PROD_GARAGE_KEY_ID }} | ||||
|       PROD_GARAGE_SECRET_KEY: ${{ secrets.PROD_GARAGE_SECRET_KEY }} | ||||
|       CF_API_TOKEN: ${{ secrets.CF_API_TOKEN }} | ||||
|       CF_ACCOUNT_ID: ${{ secrets.CF_ACCOUNT_ID }} | ||||
|       CLUSTER_USERNAME: ${{ secrets.CLUSTER_USERNAME }} | ||||
| @@ -99,5 +112,5 @@ jobs: | ||||
|  | ||||
|   cleanup: | ||||
|     if: ${{ always() }} | ||||
|     needs: build | ||||
|     needs: [build, build_blog] | ||||
|     uses: privacyguides/.github/.github/workflows/cleanup.yml@main | ||||
|   | ||||
							
								
								
									
										2
									
								
								.github/workflows/test-build.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						| @@ -41,7 +41,7 @@ jobs: | ||||
|     needs: submodule | ||||
|     strategy: | ||||
|       matrix: | ||||
|         lang: [en, es, fr, he, it, nl, ru, zh-Hant] | ||||
|         lang: [en, fr, he] | ||||
|         build: [build, offline] | ||||
|       fail-fast: false | ||||
|     permissions: | ||||
|   | ||||
							
								
								
									
										4
									
								
								.github/workflows/test-lint.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						| @@ -103,7 +103,7 @@ jobs: | ||||
|       - id: ml | ||||
|         # You can override MegaLinter flavor used to have faster performances | ||||
|         # More info at https://megalinter.io/flavors/ | ||||
|         uses: oxsecurity/megalinter/flavors/documentation@v7.10.0 | ||||
|         uses: oxsecurity/megalinter/flavors/documentation@v8.0.0 | ||||
|         env: | ||||
|           # All available variables are described in documentation | ||||
|           # https://megalinter.io/configuration/ | ||||
| @@ -113,7 +113,7 @@ jobs: | ||||
|           # ADD YOUR CUSTOM ENV VARIABLES HERE OR DEFINE THEM IN A FILE .mega-linter.yml AT THE ROOT OF YOUR REPOSITORY | ||||
|           DISABLE: COPYPASTE,SPELL,HTML | ||||
|           DISABLE_LINTERS: JSON_JSONLINT,MARKDOWN_MARKDOWN_TABLE_FORMATTER | ||||
|           DISABLE_ERRORS_LINTERS: CSS_STYLELINT,MARKDOWN_MARKDOWN_LINK_CHECK,YAML_YAMLLINT,DOCKERFILE_HADOLINT,REPOSITORY_TRIVY,REPOSITORY_CHECKOV | ||||
|           DISABLE_ERRORS_LINTERS: CSS_STYLELINT,MARKDOWN_MARKDOWN_LINK_CHECK,YAML_YAMLLINT,DOCKERFILE_HADOLINT,REPOSITORY_TRIVY,REPOSITORY_CHECKOV,REPOSITORY_GITLEAKS | ||||
|           EDITORCONFIG_EDITORCONFIG_CHECKER_ARGUMENTS: -disable-indentation | ||||
|           ENV_DOTENV_LINTER_ARGUMENTS: "--skip QuoteCharacter" | ||||
|           MARKDOWN_MARKDOWN_LINK_CHECK_FILTER_REGEX_INCLUDE: (docs) | ||||
|   | ||||
							
								
								
									
										82
									
								
								.github/workflows/update-discussions.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,82 @@ | ||||
| # Copyright (c) 2024 Jonah Aragon <jonah@triplebit.net> | ||||
|  | ||||
| # Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
| # of this software and associated documentation files (the "Software"), to | ||||
| # deal in the Software without restriction, including without limitation the | ||||
| # rights to use, copy, modify, merge, publish, distribute, sublicense, and/or | ||||
| # sell copies of the Software, and to permit persons to whom the Software is | ||||
| # furnished to do so, subject to the following conditions: | ||||
|  | ||||
| # The above copyright notice and this permission notice shall be included in | ||||
| # all copies or substantial portions of the Software. | ||||
|  | ||||
| # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
| # IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
| # FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT. IN NO EVENT SHALL THE | ||||
| # AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
| # LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING | ||||
| # FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS | ||||
| # IN THE SOFTWARE. | ||||
|  | ||||
| name: 🔄 Update Discussions | ||||
|  | ||||
| on: | ||||
|   workflow_dispatch: | ||||
|   schedule: | ||||
|     - cron: "*/30 * * * *" | ||||
|  | ||||
| permissions: | ||||
|   contents: read | ||||
|  | ||||
| jobs: | ||||
|   generate: | ||||
|     runs-on: ubuntu-latest | ||||
|     permissions: | ||||
|       contents: read | ||||
|     environment: | ||||
|       name: production | ||||
|     steps: | ||||
|       - name: Checkout | ||||
|         uses: actions/checkout@v4 | ||||
|         with: | ||||
|           persist-credentials: "false" | ||||
|           fetch-depth: 1 | ||||
|  | ||||
|       - name: Create site/en directory | ||||
|         run: mkdir -p site/en | ||||
|  | ||||
|       - name: Update Discussions | ||||
|         uses: yakubique/minio-download@v1.1.1 | ||||
|         with: | ||||
|           endpoint: https://${{ vars.PROD_GARAGE_HOSTNAME }} | ||||
|           access_key: ${{ secrets.PROD_GARAGE_KEY_ID }} | ||||
|           secret_key: ${{ secrets.PROD_GARAGE_SECRET_KEY }} | ||||
|           bucket: ${{ vars.PROD_GARAGE_BUCKET }} | ||||
|           source: /en/index.html | ||||
|           target: ./site/en/ | ||||
|  | ||||
|       - name: Run index-generation.sh for top posts | ||||
|         run: | | ||||
|           bash index-generation.sh \ | ||||
|             --source='https://discuss.privacyguides.net/top.json?period=weekly' \ | ||||
|             --tag="top posts" \ | ||||
|             --destination="./site/en/index.html" \ | ||||
|             --count=3 | ||||
|  | ||||
|       - name: Run index-generation.sh for latest posts | ||||
|         run: | | ||||
|           bash index-generation.sh \ | ||||
|             --source='https://discuss.privacyguides.net/latest.json' \ | ||||
|             --tag="latest posts" \ | ||||
|             --destination="./site/en/index.html" \ | ||||
|             --count=12 | ||||
|  | ||||
|       - name: Upload modified index | ||||
|         uses: yakubique/minio-upload@v1.1.3 | ||||
|         with: | ||||
|           endpoint: https://${{ vars.PROD_GARAGE_HOSTNAME }} | ||||
|           access_key: ${{ secrets.PROD_GARAGE_KEY_ID }} | ||||
|           secret_key: ${{ secrets.PROD_GARAGE_SECRET_KEY }} | ||||
|           bucket: ${{ vars.PROD_GARAGE_BUCKET }} | ||||
|           source: ./site/en/index.html | ||||
|           target: /en | ||||
							
								
								
									
										2
									
								
								.github/workflows/upload-crowdin.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						| @@ -41,7 +41,7 @@ jobs: | ||||
|         uses: actions/checkout@v4 | ||||
|  | ||||
|       - name: crowdin action | ||||
|         uses: crowdin/github-action@v1.20.2 | ||||
|         uses: crowdin/github-action@v2.2.0 | ||||
|         with: | ||||
|           upload_sources: true | ||||
|           upload_sources_args: "--auto-update --delete-obsolete" | ||||
|   | ||||
							
								
								
									
										16
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						| @@ -1,6 +1,6 @@ | ||||
| site | ||||
| /i18n/ | ||||
| /includes/* | ||||
| /includes/*.*.* | ||||
| !/includes/*.en.* | ||||
| /static/i18n/ | ||||
| /theme/overrides/*.*.* | ||||
| @@ -9,13 +9,11 @@ site | ||||
| # see: https://github.com/squidfunk/mkdocs-material/issues/6983 | ||||
| # ridiculous hide-and-seek https://stackoverflow.com/a/72380673 | ||||
| .cache/* | ||||
| !/config/.cache | ||||
| /config/.cache/* | ||||
| !/config/.cache/plugin | ||||
| /config/.cache/plugin/* | ||||
| !/config/.cache/plugin/social | ||||
| /config/.cache/plugin/social/* | ||||
| !/config/.cache/plugin/social/fonts | ||||
| !.cache/plugin | ||||
| /.cache/plugin/* | ||||
| !.cache/plugin/social | ||||
| /.cache/plugin/social/* | ||||
| !.cache/plugin/social/fonts | ||||
|  | ||||
| # Local Netlify folder | ||||
| .netlify | ||||
| @@ -23,3 +21,5 @@ node_modules | ||||
|  | ||||
| # Python | ||||
| .venv | ||||
| .env | ||||
| .mkdocs-insiders-* | ||||
|   | ||||
							
								
								
									
										16
									
								
								.mailmap
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,16 @@ | ||||
| Daniel Gray <dngray@privacyguides.org> <dng@disroot.org> | ||||
| Daniel Gray <dngray@privacyguides.org> <48640805+dngray@users.noreply.github.com> | ||||
| Daniel Gray <dngray@privacyguides.org> <dngray@privacytools.io> | ||||
| Daniel Gray <dngray@privacyguides.org> | ||||
| Jonah Aragon <jonah@privacyguides.org> <jonah@triplebit.net> | ||||
| Jonah Aragon <jonah@privacyguides.org> <jonah@privacytools.io> | ||||
| Jonah Aragon <jonah@privacyguides.org> <github@aragon.science> | ||||
| mfwmyfacewhen <mfw@privacyguides.org> <94880365+mfwmyfacewhen@users.noreply.github.com> | ||||
| mbananasynergy <mbananasynergy@privacyguides.org> <> | ||||
| mbananasynergy <mbananasynergy@privacyguides.org> <107055883+matchboxbananasynergy@users.noreply.github.com> | ||||
| rollsicecream <rollsicecream@proton.me> <153316540+rollsicecream@users.noreply.github.com> | ||||
| rollsicecream <rollsicecream@proton.me> <waterfallnet@proton.me> | ||||
| Freddy <freddy@privacyguides.org> <freddy@decypher.pw> | ||||
| Freddy <freddy@privacyguides.org> <freddy@privacytools.io> | ||||
| Niek de Wilde <niek@privacyguides.org> <github.ef27z@simplelogin.com> | ||||
| Niek de Wilde <niek@privacyguides.org> <blacklight447@privacytools.io> | ||||
							
								
								
									
										10
									
								
								CITATION.cff
									
									
									
									
									
								
							
							
						
						| @@ -32,11 +32,11 @@ authors: | ||||
| repository-code: "https://github.com/privacyguides/privacyguides.org" | ||||
| license: | ||||
|   - MIT | ||||
|   - CC-BY-ND-4.0 | ||||
|   - CC-BY-SA-4.0 | ||||
| references: | ||||
|   - authors: | ||||
|     - family-names: Donath | ||||
|       given-names: Martin | ||||
|       - family-names: Donath | ||||
|         given-names: Martin | ||||
|     title: "mkdocs-material" | ||||
|     type: software | ||||
|     repository-code: "https://github.com/squidfunk/mkdocs-material" | ||||
| @@ -81,7 +81,7 @@ preferred-citation: | ||||
|     - alias: samsepi0l | ||||
|       website: "https://github.com/d4rklynk" | ||||
|     - name: Privacy Guides Contributors | ||||
|       website: "https://github.com/privacyguides/privacyguides.org/graphs/contributors" | ||||
|       website: "https://www.privacyguides.org/en/about/contributors/" | ||||
|   url: "https://www.privacyguides.org" | ||||
|   abstract: >- | ||||
|     Privacy Guides is a socially motivated website that | ||||
| @@ -95,4 +95,4 @@ preferred-citation: | ||||
|     - encryption | ||||
|     - website | ||||
|     - markdown | ||||
|   license: CC-BY-ND-4.0 | ||||
|   license: CC-BY-SA-4.0 | ||||
|   | ||||
							
								
								
									
										15
									
								
								Dockerfile
									
									
									
									
									
								
							
							
						
						| @@ -1,4 +1,4 @@ | ||||
| FROM python:3.12-alpine as base | ||||
| FROM python:3.13-alpine as base | ||||
|  | ||||
| LABEL org.opencontainers.image.source="https://github.com/privacyguides/privacyguides.org" | ||||
|  | ||||
| @@ -43,7 +43,8 @@ RUN \ | ||||
|     tini \ | ||||
|     zlib-dev \ | ||||
|     libffi-dev \ | ||||
|     musl-dev | ||||
|     musl-dev \ | ||||
|     bash | ||||
|  | ||||
| # Copy virtual env from python-deps stage | ||||
| COPY --from=python-deps /.venv /.venv | ||||
| @@ -57,9 +58,9 @@ WORKDIR /site | ||||
| COPY docs docs | ||||
| COPY theme theme | ||||
| COPY includes includes | ||||
| COPY config/*.yml config/ | ||||
| COPY config/layouts config/layouts | ||||
| COPY config/.cache/plugin/social/fonts config/.cache/plugin/social/fonts | ||||
| COPY *.yml . | ||||
| COPY .cache/plugin/social/fonts .cache/plugin/social/fonts | ||||
| COPY run.sh . | ||||
|  | ||||
| EXPOSE 8000 | ||||
|  | ||||
| @@ -67,5 +68,5 @@ ENV MKDOCS_INHERIT mkdocs-production.yml | ||||
|  | ||||
| HEALTHCHECK NONE | ||||
|  | ||||
| ENTRYPOINT ["mkdocs"] | ||||
| CMD ["serve", "--dev-addr=0.0.0.0:8000", "--config-file=config/mkdocs.en.yml"] | ||||
| ENTRYPOINT ["./run.sh"] | ||||
| CMD ["--cmd=mkdocs", "--insiders", "--cmd_flags=--dev-addr=0.0.0.0:8000"] | ||||
|   | ||||
							
								
								
									
										103
									
								
								LICENSE
									
									
									
									
									
								
							
							
						
						| @@ -1,4 +1,4 @@ | ||||
| Attribution-NoDerivatives 4.0 International | ||||
| Attribution-ShareAlike 4.0 International | ||||
|  | ||||
| ======================================================================= | ||||
|  | ||||
| @@ -33,7 +33,7 @@ exhaustive, and do not form part of our licenses. | ||||
|      material not subject to the license. This includes other CC- | ||||
|      licensed material, or material used under an exception or | ||||
|      limitation to copyright. More considerations for licensors: | ||||
|     wiki.creativecommons.org/Considerations_for_licensors | ||||
|      wiki.creativecommons.org/Considerations_for_licensors | ||||
|  | ||||
|      Considerations for the public: By using one of our public | ||||
|      licenses, a licensor grants the public permission to use the | ||||
| @@ -50,17 +50,16 @@ exhaustive, and do not form part of our licenses. | ||||
|      Although not required by our licenses, you are encouraged to | ||||
|      respect those requests where reasonable. More considerations | ||||
|      for the public: | ||||
|     wiki.creativecommons.org/Considerations_for_licensees | ||||
|  | ||||
|      wiki.creativecommons.org/Considerations_for_licensees | ||||
|  | ||||
| ======================================================================= | ||||
|  | ||||
| Creative Commons Attribution-NoDerivatives 4.0 International Public | ||||
| Creative Commons Attribution-ShareAlike 4.0 International Public | ||||
| License | ||||
|  | ||||
| By exercising the Licensed Rights (defined below), You accept and agree | ||||
| to be bound by the terms and conditions of this Creative Commons | ||||
| Attribution-NoDerivatives 4.0 International Public License ("Public | ||||
| Attribution-ShareAlike 4.0 International Public License ("Public | ||||
| License"). To the extent this Public License may be interpreted as a | ||||
| contract, You are granted the Licensed Rights in consideration of Your | ||||
| acceptance of these terms and conditions, and the Licensor grants You | ||||
| @@ -81,7 +80,15 @@ Section 1 -- Definitions. | ||||
|      Adapted Material is always produced where the Licensed Material is | ||||
|      synched in timed relation with a moving image. | ||||
|  | ||||
|   b. Copyright and Similar Rights means copyright and/or similar rights | ||||
|   b. Adapter's License means the license You apply to Your Copyright | ||||
|      and Similar Rights in Your contributions to Adapted Material in | ||||
|      accordance with the terms and conditions of this Public License. | ||||
|  | ||||
|   c. BY-SA Compatible License means a license listed at | ||||
|      creativecommons.org/compatiblelicenses, approved by Creative | ||||
|      Commons as essentially the equivalent of this Public License. | ||||
|  | ||||
|   d. Copyright and Similar Rights means copyright and/or similar rights | ||||
|      closely related to copyright including, without limitation, | ||||
|      performance, broadcast, sound recording, and Sui Generis Database | ||||
|      Rights, without regard to how the rights are labeled or | ||||
| @@ -89,29 +96,33 @@ Section 1 -- Definitions. | ||||
|      specified in Section 2(b)(1)-(2) are not Copyright and Similar | ||||
|      Rights. | ||||
|  | ||||
|   c. Effective Technological Measures means those measures that, in the | ||||
|   e. Effective Technological Measures means those measures that, in the | ||||
|      absence of proper authority, may not be circumvented under laws | ||||
|      fulfilling obligations under Article 11 of the WIPO Copyright | ||||
|      Treaty adopted on December 20, 1996, and/or similar international | ||||
|      agreements. | ||||
|  | ||||
|   d. Exceptions and Limitations means fair use, fair dealing, and/or | ||||
|   f. Exceptions and Limitations means fair use, fair dealing, and/or | ||||
|      any other exception or limitation to Copyright and Similar Rights | ||||
|      that applies to Your use of the Licensed Material. | ||||
|  | ||||
|   e. Licensed Material means the artistic or literary work, database, | ||||
|   g. License Elements means the license attributes listed in the name | ||||
|      of a Creative Commons Public License. The License Elements of this | ||||
|      Public License are Attribution and ShareAlike. | ||||
|  | ||||
|   h. Licensed Material means the artistic or literary work, database, | ||||
|      or other material to which the Licensor applied this Public | ||||
|      License. | ||||
|  | ||||
|   f. Licensed Rights means the rights granted to You subject to the | ||||
|   i. Licensed Rights means the rights granted to You subject to the | ||||
|      terms and conditions of this Public License, which are limited to | ||||
|      all Copyright and Similar Rights that apply to Your use of the | ||||
|      Licensed Material and that the Licensor has authority to license. | ||||
|  | ||||
|   g. Licensor means the individual(s) or entity(ies) granting rights | ||||
|   j. Licensor means the individual(s) or entity(ies) granting rights | ||||
|      under this Public License. | ||||
|  | ||||
|   h. Share means to provide material to the public by any means or | ||||
|   k. Share means to provide material to the public by any means or | ||||
|      process that requires permission under the Licensed Rights, such | ||||
|      as reproduction, public display, public performance, distribution, | ||||
|      dissemination, communication, or importation, and to make material | ||||
| @@ -119,13 +130,13 @@ Section 1 -- Definitions. | ||||
|      public may access the material from a place and at a time | ||||
|      individually chosen by them. | ||||
|  | ||||
|   i. Sui Generis Database Rights means rights other than copyright | ||||
|   l. Sui Generis Database Rights means rights other than copyright | ||||
|      resulting from Directive 96/9/EC of the European Parliament and of | ||||
|      the Council of 11 March 1996 on the legal protection of databases, | ||||
|      as amended and/or succeeded, as well as other essentially | ||||
|      equivalent rights anywhere in the world. | ||||
|  | ||||
|   j. You means the individual or entity exercising the Licensed Rights | ||||
|   m. You means the individual or entity exercising the Licensed Rights | ||||
|      under this Public License. Your has a corresponding meaning. | ||||
|  | ||||
|  | ||||
| @@ -141,7 +152,7 @@ Section 2 -- Scope. | ||||
|             a. reproduce and Share the Licensed Material, in whole or | ||||
|                in part; and | ||||
|  | ||||
|             b. produce and reproduce, but not Share, Adapted Material. | ||||
|             b. produce, reproduce, and Share Adapted Material. | ||||
|  | ||||
|        2. Exceptions and Limitations. For the avoidance of doubt, where | ||||
|           Exceptions and Limitations apply to Your use, this Public | ||||
| @@ -171,7 +182,13 @@ Section 2 -- Scope. | ||||
|                Licensed Rights under the terms and conditions of this | ||||
|                Public License. | ||||
|  | ||||
|             b. No downstream restrictions. You may not offer or impose | ||||
|             b. Additional offer from the Licensor -- Adapted Material. | ||||
|                Every recipient of Adapted Material from You | ||||
|                automatically receives an offer from the Licensor to | ||||
|                exercise the Licensed Rights in the Adapted Material | ||||
|                under the conditions of the Adapter's License You apply. | ||||
|  | ||||
|             c. No downstream restrictions. You may not offer or impose | ||||
|                any additional or different terms or conditions on, or | ||||
|                apply any Effective Technological Measures to, the | ||||
|                Licensed Material if doing so restricts exercise of the | ||||
| @@ -213,7 +230,8 @@ following conditions. | ||||
|  | ||||
|   a. Attribution. | ||||
|  | ||||
|        1. If You Share the Licensed Material, You must: | ||||
|        1. If You Share the Licensed Material (including in modified | ||||
|           form), You must: | ||||
|  | ||||
|             a. retain the following if it is supplied by the Licensor | ||||
|                with the Licensed Material: | ||||
| @@ -241,9 +259,6 @@ following conditions. | ||||
|                Public License, and include the text of, or the URI or | ||||
|                hyperlink to, this Public License. | ||||
|  | ||||
|           For the avoidance of doubt, You do not have permission under | ||||
|           this Public License to Share Adapted Material. | ||||
|  | ||||
|        2. You may satisfy the conditions in Section 3(a)(1) in any | ||||
|           reasonable manner based on the medium, means, and context in | ||||
|           which You Share the Licensed Material. For example, it may be | ||||
| @@ -255,6 +270,25 @@ following conditions. | ||||
|           information required by Section 3(a)(1)(A) to the extent | ||||
|           reasonably practicable. | ||||
|  | ||||
|   b. ShareAlike. | ||||
|  | ||||
|      In addition to the conditions in Section 3(a), if You Share | ||||
|      Adapted Material You produce, the following conditions also apply. | ||||
|  | ||||
|        1. The Adapter's License You apply must be a Creative Commons | ||||
|           license with the same License Elements, this version or | ||||
|           later, or a BY-SA Compatible License. | ||||
|  | ||||
|        2. You must include the text of, or the URI or hyperlink to, the | ||||
|           Adapter's License You apply. You may satisfy this condition | ||||
|           in any reasonable manner based on the medium, means, and | ||||
|           context in which You Share Adapted Material. | ||||
|  | ||||
|        3. You may not offer or impose any additional or different terms | ||||
|           or conditions on, or apply any Effective Technological | ||||
|           Measures to, Adapted Material that restrict exercise of the | ||||
|           rights granted under the Adapter's License You apply. | ||||
|  | ||||
|  | ||||
| Section 4 -- Sui Generis Database Rights. | ||||
|  | ||||
| @@ -263,13 +297,13 @@ apply to Your use of the Licensed Material: | ||||
|  | ||||
|   a. for the avoidance of doubt, Section 2(a)(1) grants You the right | ||||
|      to extract, reuse, reproduce, and Share all or a substantial | ||||
|      portion of the contents of the database, provided You do not Share | ||||
|      Adapted Material; | ||||
|      portion of the contents of the database; | ||||
|  | ||||
|   b. if You include all or a substantial portion of the database | ||||
|      contents in a database in which You have Sui Generis Database | ||||
|      Rights, then the database in which You have Sui Generis Database | ||||
|      Rights (but not its individual contents) is Adapted Material; and | ||||
|      Rights (but not its individual contents) is Adapted Material, | ||||
|      including for purposes of Section 3(b); and | ||||
|  | ||||
|   c. You must comply with the conditions in Section 3(a) if You Share | ||||
|      all or a substantial portion of the contents of the database. | ||||
| @@ -370,23 +404,24 @@ Section 8 -- Interpretation. | ||||
|      that apply to the Licensor or You, including from the legal | ||||
|      processes of any jurisdiction or authority. | ||||
|  | ||||
|  | ||||
| ======================================================================= | ||||
|  | ||||
| Creative Commons is not a party to its public | ||||
| licenses. Notwithstanding, Creative Commons may elect to apply one of | ||||
| its public licenses to material it publishes and in those instances | ||||
| will be considered the “Licensor.” The text of the Creative Commons | ||||
| public licenses is dedicated to the public domain under the CC0 Public | ||||
| Domain Dedication. Except for the limited purpose of indicating that | ||||
| material is shared under a Creative Commons public license or as | ||||
| otherwise permitted by the Creative Commons policies published at | ||||
| Creative Commons is not a party to its public licenses. | ||||
| Notwithstanding, Creative Commons may elect to apply one of its public | ||||
| licenses to material it publishes and in those instances will be | ||||
| considered the “Licensor.” The text of the Creative Commons public | ||||
| licenses is dedicated to the public domain under the CC0 Public Domain | ||||
| Dedication. Except for the limited purpose of indicating that material | ||||
| is shared under a Creative Commons public license or as otherwise | ||||
| permitted by the Creative Commons policies published at | ||||
| creativecommons.org/policies, Creative Commons does not authorize the | ||||
| use of the trademark "Creative Commons" or any other trademark or logo | ||||
| of Creative Commons without its prior written consent including, | ||||
| without limitation, in connection with any unauthorized modifications | ||||
| to any of its public licenses or any other arrangements, | ||||
| understandings, or agreements concerning use of licensed material. For | ||||
| the avoidance of doubt, this paragraph does not form part of the | ||||
| public licenses. | ||||
| the avoidance of doubt, this paragraph does not form part of the public | ||||
| licenses. | ||||
|  | ||||
| Creative Commons may be contacted at creativecommons.org. | ||||
|   | ||||
							
								
								
									
										4
									
								
								Pipfile
									
									
									
									
									
								
							
							
						
						| @@ -26,9 +26,11 @@ name = "pypi" | ||||
| [packages] | ||||
| mkdocs-material = {extras = ["imaging"], path = "./modules/mkdocs-material"} | ||||
| mkdocs-git-revision-date-localized-plugin = "~=1.2" | ||||
| mkdocs-git-committers-plugin-2 = "~=1.1" | ||||
| mkdocs-git-authors-plugin = "~=0.8" | ||||
| mkdocs-macros-plugin = "~=1.0" | ||||
| jieba = "~=0.42" | ||||
| mkdocs-rss-plugin = "*" | ||||
| mkdocs-glightbox = "*" | ||||
|  | ||||
| [dev-packages] | ||||
| scour = "~=0.38" | ||||
|   | ||||
							
								
								
									
										1394
									
								
								Pipfile.lock
									
									
									
										generated
									
									
									
								
							
							
						
						
							
								
								
									
										553
									
								
								README.md
									
									
									
									
									
								
							
							
						
						| @@ -10,39 +10,43 @@ | ||||
|   <p><em>Your central privacy and security resource to protect yourself online.</em></p> | ||||
|  | ||||
|   <p><a href="https://discuss.privacyguides.net"> | ||||
|     <img src="https://img.shields.io/discourse/users?label=Join%20our%20forum&logo=discourse&server=https%3A%2F%2Fdiscuss.privacyguides.net&style=social"> | ||||
|   </a> | ||||
|     <img src="https://img.shields.io/discourse/users?label=Join%20our%20forum&logo=discourse&server=https%3A%2F%2Fdiscuss.privacyguides.net&style=social"></a> | ||||
|   <a href="https://github.com/privacyguides/privacyguides.org/stargazers"> | ||||
|     <img src="https://img.shields.io/github/stars/privacyguides?style=social"> | ||||
|   </a> | ||||
|     <img src="https://img.shields.io/github/stars/privacyguides?style=social"></a> | ||||
|   <a href="https://mastodon.neat.computer/@privacyguides"> | ||||
|     <img src="https://img.shields.io/mastodon/follow/109298532634697668?domain=https%3A%2F%2Fmastodon.neat.computer&label=Follow%20%40privacyguides%40neat.computer&style=social"> | ||||
|   </a> | ||||
|   <a href="https://lemmy.one/c/privacyguides"> | ||||
|     <img src="https://img.shields.io/lemmy/privacyguides%40lemmy.one?style=social"> | ||||
|   </a></p> | ||||
|     <img src="https://img.shields.io/mastodon/follow/109298532634697668?domain=https%3A%2F%2Fmastodon.neat.computer&label=Follow&style=social"></a> | ||||
|   <a href="https://bsky.app/profile/privacyguides.org"> | ||||
|     <img src="https://img.shields.io/badge/dynamic/json?url=https%3A%2F%2Fpublic.api.bsky.app%2Fxrpc%2Fapp.bsky.actor.getProfile%3Factor%3Dprivacyguides.org&query=%24.followersCount&style=social&logo=bluesky&label=Follow"></a></p> | ||||
|  | ||||
|   <p><a href="https://github.com/privacyguides/privacyguides.org/pulls"> | ||||
|     <img src="https://img.shields.io/github/issues-pr-raw/privacyguides/privacyguides.org"> | ||||
|   </a> | ||||
|     <img src="https://img.shields.io/github/issues-pr-raw/privacyguides/privacyguides.org"></a> | ||||
|   <a href="https://github.com/privacyguides/privacyguides.org/pulls?q=is%3Apr+is%3Aclosed"> | ||||
|     <img src="https://img.shields.io/github/issues-pr-closed-raw/privacyguides/privacyguides.org"> | ||||
|   </a> | ||||
|     <img src="https://img.shields.io/github/issues-pr-closed-raw/privacyguides/privacyguides.org"></a> | ||||
|   <a href="https://github.com/privacyguides/privacyguides.org/graphs/contributors"> | ||||
|     <img src="https://img.shields.io/github/commit-activity/m/privacyguides/privacyguides.org"></a> | ||||
|   <a href="#contributors"> | ||||
|     <img src="https://img.shields.io/github/all-contributors/privacyguides/privacyguides.org"></a> | ||||
|   <a href="https://github.com/privacyguides/privacyguides.org/releases/latest"> | ||||
|     <img src="https://img.shields.io/github/release-date/privacyguides/privacyguides.org"></a> | ||||
|   <a href="https://github.com/privacyguides/privacyguides.org/releases/latest"> | ||||
|     <img src="https://img.shields.io/github/commits-since/privacyguides/privacyguides.org/latest"></a> | ||||
|   <a href="https://crowdin.com/project/privacyguides"> | ||||
|     <img src="https://badges.crowdin.net/privacyguides/localized.svg"> | ||||
|   </a> | ||||
|   <a href="https://opencollective.com/privacyguides"> | ||||
|     <img src="https://img.shields.io/opencollective/all/privacyguides"> | ||||
|   </a></p> | ||||
|     <img src="https://badges.crowdin.net/privacyguides/localized.svg"></a> | ||||
|   <a href="https://github.com/sponsors/privacyguides#sponsors"> | ||||
|     <img src="https://img.shields.io/github/sponsors/privacyguides"></a> | ||||
|   <a href="https://squidfunk.github.io/mkdocs-material/"> | ||||
|     <img src="https://img.shields.io/badge/Material_for_MkDocs-526CFE?logo=MaterialForMkDocs&logoColor=white"></a> | ||||
|   <a href="https://github.com/privacyguides/privacyguides.org/actions/workflows/publish-release.yml"> | ||||
|     <img src="https://img.shields.io/github/actions/workflow/status/privacyguides/privacyguides.org/publish-release.yml?label=release"></a></p> | ||||
| </div> | ||||
|  | ||||
| ## About | ||||
|  | ||||
| **Privacy Guides** is a socially motivated website that provides information for protecting your data security and privacy. Our mission is to inform the public about the value of digital privacy, and global government initiatives which aim to monitor your online activity. We are a non-profit collective operated entirely by volunteer team members and contributors. Our website is free of advertisements and not affiliated with any of the listed providers. | ||||
|  | ||||
| The current list of team members can be found [here](https://www.privacyguides.org/about/#our-team). Additionally, [many people](https://github.com/privacyguides/privacyguides.org/graphs/contributors) have made contributions to the project, and you can too! | ||||
| The current list of team members can be found [here](https://www.privacyguides.org/en/about/#executive-committee). Additionally, [many people](#contributors) have made contributions to the project, and you can too! | ||||
|  | ||||
| *Featured on: [Tweakers](https://tweakers.net/reviews/10568/op-zoek-naar-privacyvriendelijke-tools-niek-de-wilde-van-privacy-guides.html), [The New York Times](https://nytimes.com/wirecutter/guides/online-security-social-media-privacy), and [Wired](https://wired.com/story/firefox-mozilla-2022)* | ||||
| *Featured on: [Tweakers](https://tweakers.net/reviews/10568/op-zoek-naar-privacyvriendelijke-tools-niek-de-wilde-van-privacy-guides.html), [The New York Times](https://nytimes.com/wirecutter/guides/online-security-social-media-privacy), [Wired](https://wired.com/story/firefox-mozilla-2022), and [Fast Company](https://www.fastcompany.com/91167564/mozilla-wants-you-to-love-firefox-again).* | ||||
|  | ||||
| ## Contributing | ||||
|  | ||||
| @@ -54,7 +58,7 @@ The current list of team members can be found [here](https://www.privacyguides.o | ||||
|     - View the list of [approved topics waiting for a PR](https://discuss.privacyguides.net/tag/approved) | ||||
|     - Read some writing tips in our [style guide](https://www.privacyguides.org/en/meta/writing-style) | ||||
|  | ||||
| All contributors to the site are listed [here](https://github.com/privacyguides/privacyguides.org/graphs/contributors). If you make a substantial (i.e. copyright eligible) contribution to the project and would like to be formally credited, you are welcome to include your information in the appropriate `authors` section in [`CITATION.cff`](/CITATION.cff) as well, just submit a PR or ask @jonaharagon to make the change. | ||||
| All contributors to the site are listed [here](#contributors). If you have contributed to the website or project, please [add yourself](https://github.com/privacyguides/privacyguides.org/issues/2524) to the list or ask @jonaharagon to make the change. | ||||
|  | ||||
| ## Mirrors | ||||
|  | ||||
| @@ -92,9 +96,9 @@ All contributors to the site are listed [here](https://github.com/privacyguides/ | ||||
|  | ||||
| ## License | ||||
|  | ||||
| Copyright © 2019 - 2024 [Privacy Guides contributors](https://github.com/privacyguides/privacyguides.org/graphs/contributors). | ||||
| Copyright © 2019 - 2024 [Privacy Guides contributors](#contributors). | ||||
|  | ||||
| Privacy Guides content is licensed under the [Creative Commons Attribution-NoDerivatives 4.0 International Public License](/LICENSE), and the underlying source code used to format and display that content on [www.privacyguides.org](https://www.privacyguides.org) is licensed under the [MIT License](/LICENSE-CODE). | ||||
| Privacy Guides content is licensed under the [Creative Commons Attribution-ShareAlike 4.0 International Public License](/LICENSE), and the underlying source code used to format and display that content on [www.privacyguides.org](https://www.privacyguides.org) is licensed under the [MIT License](/LICENSE-CODE). | ||||
|  | ||||
| Generally speaking, **content** can be found in the [`/docs`](/docs), [`/theme/assets/img`](/theme/assets/img) and [`/includes`](/includes) folders; and **source code** and configuration files can be found in the [`/config`](/config) and [`/theme`](/theme) folders, and in the root of this repository. Any source code snippets contained within documentation files are [MIT Licensed](/LICENSE-CODE). Please contact us if you require clarification on any of these terms. | ||||
|  | ||||
| @@ -108,16 +112,18 @@ When you contribute to this repository you are doing so under the above licenses | ||||
|  | ||||
| ## Developing | ||||
|  | ||||
| [](https://codespaces.new/privacyguides/privacyguides.org?devcontainer_path=.devcontainer%2Fdevcontainer.json) | ||||
|  | ||||
| Committing to this repository requires [signing your commits](https://docs.github.com/en/authentication/managing-commit-signature-verification/signing-commits) (`git config commit.gpgsign true`) unless you are making edits via the GitHub.com text editor interface. As of August 2022 the preferred signing method is [SSH commit signatures](https://docs.github.com/en/authentication/managing-commit-signature-verification/about-commit-signature-verification#ssh-commit-signature-verification), but GPG signing is also acceptable. You should add your signing key to your GitHub profile. | ||||
|  | ||||
| ### With `mkdocs-material` | ||||
|  | ||||
| 1. Install required packages: `pip install mkdocs-material` | ||||
| 2. Run a local preview of the English site: `mkdocs serve --config-file config/mkdocs.en.yml` | ||||
| 2. Run a local preview of the English site: `./run.sh --cmd=mkdocs` | ||||
|  | ||||
| ### With `mkdocs-material-insiders` | ||||
|  | ||||
| This website uses [`mkdocs-material-insiders`](https://squidfunk.github.io/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. 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. | ||||
| This website uses [`mkdocs-material-insiders`](https://squidfunk.github.io/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. | ||||
|  | ||||
| **Team members** should clone the repository with `mkdocs-material-insiders` directly. This method is identical to production: | ||||
|  | ||||
| @@ -126,9 +132,9 @@ This website uses [`mkdocs-material-insiders`](https://squidfunk.github.io/mkdoc | ||||
| 3. Install Python **3.12**. | ||||
| 4. Install **pipenv**: `pip install pipenv` | ||||
| 5. Install dependencies: `pipenv install --dev` (install [Pillow and CairoSVG](https://squidfunk.github.io/mkdocs-material/setup/setting-up-social-cards/#dependencies) as well to generate social cards) | ||||
| 6. Serve the site locally: `MKDOCS_INHERIT=mkdocs-production.yml pipenv run mkdocs serve --config-file config/mkdocs.en.yml` (set `CARDS=true` to generate social cards) | ||||
| 6. Serve the site locally: `./run.sh --insiders` (set `CARDS=true` to generate social cards) | ||||
|     - The site will be available at `http://localhost:8000` | ||||
|     - You can build the site locally with `MKDOCS_INHERIT=mkdocs-production.yml pipenv run mkdocs build --config-file config/mkdocs.en.yml` | ||||
|     - You can build the site locally with `./run.sh --insiders --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`](/.allowed_signers) in this repo. | ||||
| @@ -138,8 +144,7 @@ If you commit to `main` with commits signed with your SSH key, you should add yo | ||||
| 1. Install the [Crowdin CLI Tool](https://developer.crowdin.com/cli-tool) (`brew install crowdin`) | ||||
| 2. Set the `CROWDIN_PERSONAL_TOKEN` environment variable to your Crowdin personal access token | ||||
| 3. Run `crowdin download` in the root of this repo | ||||
| 4. Import the language's environment variables: `set -a; source includes/strings.fr.env; set +a` (replacing fr with the appropriate language) | ||||
| 5. Serve the site locally: `pipenv run mkdocs serve --config-file config/mkdocs.fr.yml` (replacing fr with the appropriate language in [/config](/config)) | ||||
| 4. Serve the site locally: `./run.sh --insiders --lang=fr` (replacing fr with the appropriate language in [/config](/config)) | ||||
|  | ||||
| Translations downloaded from Crowdin are [.gitignore](/.gitignore)'d, so any local changes to the translated site cannot be committed to this repo. Actual modifications need to be made on Crowdin. As an alternative to steps 1-3, you can copy the folders from [privacyguides/i18n](https://github.com/privacyguides/i18n) to the root of this repo to obtain the translated files. | ||||
|  | ||||
| @@ -153,3 +158,493 @@ It is required to create a GitHub release to publish the current site to privacy | ||||
| 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. | ||||
|  | ||||
| ## Contributors | ||||
|  | ||||
| Privacy Guides wouldn't be possible without these wonderful people ([emoji key](https://allcontributors.org/docs/en/emoji-key)): | ||||
|  | ||||
| <!-- ALL-CONTRIBUTORS-LIST:START - Do not remove or modify this section --> | ||||
| <!-- prettier-ignore-start --> | ||||
| <!-- markdownlint-disable --> | ||||
| <table> | ||||
|   <tbody> | ||||
|     <tr> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://www.jonaharagon.com/"><img src="https://avatars.githubusercontent.com/u/3637842?v=4" width="100px;" loading=lazy /><br /><sub><b>Jonah Aragon</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=jonaharagon" title="Documentation">📖</a> <a href="https://github.com/privacyguides/privacyguides.org/pulls?q=is%3Apr+reviewed-by%3Ajonaharagon" title="Reviewed Pull Requests">👀</a> <a href="#projectManagement-jonaharagon" title="Project Management">📆</a> <a href="https://github.com/privacyguides/privacyguides.org/commits?author=jonaharagon" title="Code">💻</a> <a href="#infra-jonaharagon" title="Infrastructure (Hosting, Build-Tools, etc)">🚇</a> <a href="#security-jonaharagon" title="Security">🛡️</a> <a href="#blog-jonaharagon" title="Blogposts">📝</a> <a href="#design-jonaharagon" title="Design">🎨</a> <a href="#platform-jonaharagon" title="Packaging/porting to new platform">📦</a> <a href="#promotion-jonaharagon" title="Promotion">📣</a> <a href="#question-jonaharagon" title="Answering Questions">💬</a> <a href="#research-jonaharagon" title="Research">🔬</a> <a href="#maintenance-jonaharagon" title="Maintenance">🚧</a> <a href="#mentoring-jonaharagon" title="Mentoring">🧑🏫</a> <a href="#a11y-jonaharagon" title="Accessibility">️️️️♿️</a> <a href="#ideas-jonaharagon" title="Ideas, Planning, & Feedback">🤔</a> <a href="#video-jonaharagon" title="Videos">📹</a> <a href="https://github.com/privacyguides/privacyguides.org/issues?q=author%3Ajonaharagon" title="Bug reports">🐛</a> <a href="#business-jonaharagon" title="Business development">💼</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://polarbear.army/"><img src="https://avatars.githubusercontent.com/u/48640805?v=4" width="100px;" loading=lazy /><br /><sub><b>Daniel Nathan Gray</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=dngray" title="Documentation">📖</a> <a href="#mentoring-dngray" title="Mentoring">🧑🏫</a> <a href="#projectManagement-dngray" title="Project Management">📆</a> <a href="#question-dngray" title="Answering Questions">💬</a> <a href="#research-dngray" title="Research">🔬</a> <a href="https://github.com/privacyguides/privacyguides.org/pulls?q=is%3Apr+reviewed-by%3Adngray" title="Reviewed Pull Requests">👀</a> <a href="https://github.com/privacyguides/privacyguides.org/issues?q=author%3Adngray" title="Bug reports">🐛</a> <a href="#maintenance-dngray" title="Maintenance">🚧</a> <a href="#ideas-dngray" title="Ideas, Planning, & Feedback">🤔</a> <a href="#security-dngray" title="Security">🛡️</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://freddy.lol/"><img src="https://avatars.githubusercontent.com/u/25013506?v=4" width="100px;" loading=lazy /><br /><sub><b>Freddy</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=freddy-m" title="Documentation">📖</a> <a href="#blog-freddy-m" title="Blogposts">📝</a> <a href="https://github.com/privacyguides/privacyguides.org/pulls?q=is%3Apr+reviewed-by%3Afreddy-m" title="Reviewed Pull Requests">👀</a> <a href="#research-freddy-m" title="Research">🔬</a> <a href="#maintenance-freddy-m" title="Maintenance">🚧</a> <a href="https://github.com/privacyguides/privacyguides.org/issues?q=author%3Afreddy-m" title="Bug reports">🐛</a> <a href="#ideas-freddy-m" title="Ideas, Planning, & Feedback">🤔</a> <a href="#question-freddy-m" title="Answering Questions">💬</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/blacklight447"><img src="https://avatars.githubusercontent.com/u/50110294?v=4" width="100px;" loading=lazy /><br /><sub><b>Niek de Wilde</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=blacklight447" title="Documentation">📖</a> <a href="https://github.com/privacyguides/privacyguides.org/issues?q=author%3Ablacklight447" title="Bug reports">🐛</a> <a href="#research-blacklight447" title="Research">🔬</a> <a href="https://github.com/privacyguides/privacyguides.org/pulls?q=is%3Apr+reviewed-by%3Ablacklight447" title="Reviewed Pull Requests">👀</a> <a href="#infra-blacklight447" title="Infrastructure (Hosting, Build-Tools, etc)">🚇</a> <a href="#question-blacklight447" title="Answering Questions">💬</a> <a href="#ideas-blacklight447" title="Ideas, Planning, & Feedback">🤔</a> <a href="#blog-blacklight447" title="Blogposts">📝</a> <a href="#audio-blacklight447" title="Audio">🔊</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/hook9"><img src="https://avatars.githubusercontent.com/u/47239784?v=4" width="100px;" loading=lazy /><br /><sub><b>hook9</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=hook9" title="Documentation">📖</a> <a href="#research-hook9" title="Research">🔬</a> <a href="https://github.com/privacyguides/privacyguides.org/pulls?q=is%3Apr+reviewed-by%3Ahook9" title="Reviewed Pull Requests">👀</a> <a href="#ideas-hook9" title="Ideas, Planning, & Feedback">🤔</a></td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://aminda.eu/"><img src="https://avatars.githubusercontent.com/u/831184?v=4" width="100px;" loading=lazy /><br /><sub><b>Aminda Suomalainen ⚧</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=Mikaela" title="Documentation">📖</a> <a href="https://github.com/privacyguides/privacyguides.org/pulls?q=is%3Apr+reviewed-by%3AMikaela" title="Reviewed Pull Requests">👀</a> <a href="#ideas-Mikaela" title="Ideas, Planning, & Feedback">🤔</a> <a href="#research-Mikaela" title="Research">🔬</a> <a href="#a11y-Mikaela" title="Accessibility">️️️️♿️</a> <a href="#question-Mikaela" title="Answering Questions">💬</a> <a href="#projectManagement-Mikaela" title="Project Management">📆</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://nitrohorse.com/"><img src="https://avatars.githubusercontent.com/u/1514352?v=4" width="100px;" loading=lazy /><br /><sub><b>nitrohorse</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=nitrohorse" title="Documentation">📖</a> <a href="https://github.com/privacyguides/privacyguides.org/pulls?q=is%3Apr+reviewed-by%3Anitrohorse" title="Reviewed Pull Requests">👀</a> <a href="#ideas-nitrohorse" title="Ideas, Planning, & Feedback">🤔</a> <a href="#blog-nitrohorse" title="Blogposts">📝</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://dawidpotocki.com/"><img src="https://avatars.githubusercontent.com/u/38681822?v=4" width="100px;" loading=lazy /><br /><sub><b>Dawid Potocki</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=dawidpotocki" title="Documentation">📖</a> <a href="https://github.com/privacyguides/privacyguides.org/pulls?q=is%3Apr+reviewed-by%3Adawidpotocki" title="Reviewed Pull Requests">👀</a> <a href="#ideas-dawidpotocki" title="Ideas, Planning, & Feedback">🤔</a> <a href="#design-dawidpotocki" title="Design">🎨</a> <a href="#research-dawidpotocki" title="Research">🔬</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://realguyman.xyz/"><img src="https://avatars.githubusercontent.com/u/93285774?v=4" width="100px;" loading=lazy /><br /><sub><b>Dale E. Wingard, Jr.</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=realguyman" title="Documentation">📖</a> <a href="https://github.com/privacyguides/privacyguides.org/pulls?q=is%3Apr+reviewed-by%3Arealguyman" title="Reviewed Pull Requests">👀</a> <a href="#ideas-realguyman" title="Ideas, Planning, & Feedback">🤔</a> <a href="#research-realguyman" title="Research">🔬</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/kewde"><img src="https://avatars.githubusercontent.com/u/13770485?v=4" width="100px;" loading=lazy /><br /><sub><b>Kewde</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=kewde" title="Documentation">📖</a> <a href="https://github.com/privacyguides/privacyguides.org/commits?author=kewde" title="Code">💻</a> <a href="#research-kewde" title="Research">🔬</a></td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://vince.sh/"><img src="https://avatars.githubusercontent.com/u/13933712?v=4" width="100px;" loading=lazy /><br /><sub><b>Vince</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=Vincevrp" title="Documentation">📖</a> <a href="https://github.com/privacyguides/privacyguides.org/commits?author=Vincevrp" title="Code">💻</a> <a href="#research-Vincevrp" title="Research">🔬</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/shifterovich2"><img src="https://avatars.githubusercontent.com/u/31760859?v=4" width="100px;" loading=lazy /><br /><sub><b>shifterovich2</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=shifterovich2" title="Documentation">📖</a> <a href="https://github.com/privacyguides/privacyguides.org/commits?author=shifterovich2" title="Code">💻</a> <a href="#research-shifterovich2" title="Research">🔬</a></td> | ||||
|       <td align="center" valign="top" width="20%"><img src="https://avatars.githubusercontent.com/u/10137?v=4" width="100px;" loading=lazy /><br /><sub><b>mfwmyfacewhen</b></sub><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=mfwmyfacewhen" title="Documentation">📖</a> <a href="#ideas-mfwmyfacewhen" title="Ideas, Planning, & Feedback">🤔</a> <a href="https://github.com/privacyguides/privacyguides.org/pulls?q=is%3Apr+reviewed-by%3Amfwmyfacewhen" title="Reviewed Pull Requests">👀</a> <a href="#research-mfwmyfacewhen" title="Research">🔬</a> <a href="#question-mfwmyfacewhen" title="Answering Questions">💬</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://tommytran.io/"><img src="https://avatars.githubusercontent.com/u/57488583?v=4" width="100px;" loading=lazy /><br /><sub><b>Tommy</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=TommyTran732" title="Documentation">📖</a> <a href="https://github.com/privacyguides/privacyguides.org/pulls?q=is%3Apr+reviewed-by%3ATommyTran732" title="Reviewed Pull Requests">👀</a> <a href="#research-TommyTran732" title="Research">🔬</a> <a href="#question-TommyTran732" title="Answering Questions">💬</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://kaitebay.org/"><img src="https://avatars.githubusercontent.com/u/95620167?v=4" width="100px;" loading=lazy /><br /><sub><b>Kai Tebay</b></sub></a><br /><a href="#ideas-KaiTebay" title="Ideas, Planning, & Feedback">🤔</a> <a href="https://github.com/privacyguides/privacyguides.org/commits?author=KaiTebay" title="Documentation">📖</a> <a href="#research-KaiTebay" title="Research">🔬</a> <a href="https://github.com/privacyguides/privacyguides.org/commits?author=KaiTebay" title="Code">💻</a></td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/matchboxbananasynergy"><img src="https://avatars.githubusercontent.com/u/107055883?v=4" width="100px;" loading=lazy /><br /><sub><b>matchboxbananasynergy</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=matchboxbananasynergy" title="Documentation">📖</a> <a href="#research-matchboxbananasynergy" title="Research">🔬</a> <a href="#ideas-matchboxbananasynergy" title="Ideas, Planning, & Feedback">🤔</a> <a href="https://github.com/privacyguides/privacyguides.org/pulls?q=is%3Apr+reviewed-by%3Amatchboxbananasynergy" title="Reviewed Pull Requests">👀</a> <a href="#blog-matchboxbananasynergy" title="Blogposts">📝</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://friadev.github.io/"><img src="https://avatars.githubusercontent.com/u/138676274?v=4" width="100px;" loading=lazy /><br /><sub><b>fria</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=friadev" title="Documentation">📖</a> <a href="https://github.com/privacyguides/privacyguides.org/pulls?q=is%3Apr+reviewed-by%3Afriadev" title="Reviewed Pull Requests">👀</a> <a href="#research-friadev" title="Research">🔬</a> <a href="#question-friadev" title="Answering Questions">💬</a> <a href="https://github.com/privacyguides/privacyguides.org/issues?q=author%3Afriadev" title="Bug reports">🐛</a> <a href="#ideas-friadev" title="Ideas, Planning, & Feedback">🤔</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/features/actions"><img src="https://avatars.githubusercontent.com/u/44036562?v=4" width="100px;" loading=lazy /><br /><sub><b>GitHub Actions</b></sub></a><br /><a href="#infra-actions" title="Infrastructure (Hosting, Build-Tools, etc)">🚇</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://www.triplebit.org/"><img src="https://avatars.githubusercontent.com/u/178061783?v=4" width="100px;" loading=lazy /><br /><sub><b>Triplebit</b></sub></a><br /><a href="#infra-triplebit" title="Infrastructure (Hosting, Build-Tools, etc)">🚇</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://magicgrants.org/"><img src="https://avatars.githubusercontent.com/u/90805358?v=4" width="100px;" loading=lazy /><br /><sub><b>MAGIC Grants</b></sub></a><br /><a href="#business-magicgrants" title="Business development">💼</a></td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://www.netlify.com/"><img src="https://avatars.githubusercontent.com/u/7892489?v=4" width="100px;" loading=lazy /><br /><sub><b>Netlify</b></sub></a><br /><a href="#infra-netlify" title="Infrastructure (Hosting, Build-Tools, etc)">🚇</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/features/security"><img src="https://avatars.githubusercontent.com/u/27347476?v=4" width="100px;" loading=lazy /><br /><sub><b>Dependabot</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=dependabot" title="Code">💻</a> <a href="#infra-dependabot" title="Infrastructure (Hosting, Build-Tools, etc)">🚇</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://console.hetzner.cloud/"><img src="https://avatars.githubusercontent.com/u/22154697?v=4" width="100px;" loading=lazy /><br /><sub><b>Hetzner Cloud</b></sub></a><br /><a href="#infra-hetznercloud" title="Infrastructure (Hosting, Build-Tools, etc)">🚇</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://www.cloudflare.com/"><img src="https://avatars.githubusercontent.com/u/314135?v=4" width="100px;" loading=lazy /><br /><sub><b>Cloudflare</b></sub></a><br /><a href="#infra-cloudflare" title="Infrastructure (Hosting, Build-Tools, etc)">🚇</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://opencollective.com/"><img src="https://avatars.githubusercontent.com/u/13403593?v=4" width="100px;" loading=lazy /><br /><sub><b>Open Collective</b></sub></a><br /><a href="#business-opencollective" title="Business development">💼</a></td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://safing.io/"><img src="https://avatars.githubusercontent.com/u/20678162?v=4" width="100px;" loading=lazy /><br /><sub><b>Safing</b></sub></a><br /><a href="#financial-safing" title="Financial">💵</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://www.danarel.com/"><img src="https://avatars.githubusercontent.com/u/46383059?v=4" width="100px;" loading=lazy /><br /><sub><b>Dan Arel</b></sub></a><br /><a href="#blog-danarel" title="Blogposts">📝</a> <a href="https://github.com/privacyguides/privacyguides.org/commits?author=danarel" title="Documentation">📖</a> <a href="#research-danarel" title="Research">🔬</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://techlore.tech/"><img src="https://avatars.githubusercontent.com/u/68134985?v=4" width="100px;" loading=lazy /><br /><sub><b>Techlore</b></sub></a><br /><a href="#financial-techlore" title="Financial">💵</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/elitejake"><img src="https://avatars.githubusercontent.com/u/74049394?v=4" width="100px;" loading=lazy /><br /><sub><b>elitejake</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=elitejake" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://simpleprivacy.fr/"><img src="https://avatars.githubusercontent.com/u/74207682?v=4" width="100px;" loading=lazy /><br /><sub><b>samsepi0l</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=d4rklynk" title="Documentation">📖</a></td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/rollsicecream"><img src="https://avatars.githubusercontent.com/u/153316540?v=4" width="100px;" loading=lazy /><br /><sub><b>rollsicecream</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=rollsicecream" title="Documentation">📖</a> <a href="#question-rollsicecream" title="Answering Questions">💬</a> <a href="#translation-rollsicecream" title="Translation">🌍</a> <a href="https://github.com/privacyguides/privacyguides.org/pulls?q=is%3Apr+reviewed-by%3Arollsicecream" title="Reviewed Pull Requests">👀</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://henryfisher.tech/"><img src="https://avatars.githubusercontent.com/u/64515030?v=4" width="100px;" loading=lazy /><br /><sub><b>Henry Fisher</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=henry-fisher" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://thenewoil.org/"><img src="https://avatars.githubusercontent.com/u/133825060?v=4" width="100px;" loading=lazy /><br /><sub><b>Nate Bartram</b></sub></a><br /><a href="#blog-tnonate" title="Blogposts">📝</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://www.samhowell.uk/"><img src="https://avatars.githubusercontent.com/u/10137?v=4" width="100px;" loading=lazy /><br /><sub><b>Sam Howell</b></sub></a><br /><a href="#blog-5amm" title="Blogposts">📝</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/asddsaz"><img src="https://avatars.githubusercontent.com/u/42685606?v=4" width="100px;" loading=lazy /><br /><sub><b>asddsaz</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=asddsaz" title="Documentation">📖</a></td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/hugoncosta"><img src="https://avatars.githubusercontent.com/u/29380568?v=4" width="100px;" loading=lazy /><br /><sub><b>Hugo Costa</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=hugoncosta" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/C-O-M-P-A-R-T-M-E-N-T-A-L-I-Z-A-T-I-O-N"><img src="https://avatars.githubusercontent.com/u/30232065?v=4" width="100px;" loading=lazy /><br /><sub><b>C-O-M-P-A-R-T-M-E-N-T-A-L-I-Z-A-T-I-O-N</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=C-O-M-P-A-R-T-M-E-N-T-A-L-I-Z-A-T-I-O-N" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/Strappazzon"><img src="https://avatars.githubusercontent.com/u/19752093?v=4" width="100px;" loading=lazy /><br /><sub><b>Alberto Strappazzon</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=Strappazzon" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://victorhckinthefreeworld.com/"><img src="https://avatars.githubusercontent.com/u/1514206?v=4" width="100px;" loading=lazy /><br /><sub><b>Victorhck</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=victorhck" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/taivlam"><img src="https://avatars.githubusercontent.com/u/47955724?v=4" width="100px;" loading=lazy /><br /><sub><b>Tai Lam</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=taivlam" title="Documentation">📖</a></td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/NinebitX"><img src="https://avatars.githubusercontent.com/u/26626722?v=4" width="100px;" loading=lazy /><br /><sub><b>NinebitX</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=NinebitX" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://antukh.com/"><img src="https://avatars.githubusercontent.com/u/10441512?v=4" width="100px;" loading=lazy /><br /><sub><b>Alexander Antukh</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=c0rdis" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://gusted.xyz/"><img src="https://avatars.githubusercontent.com/u/25481501?v=4" width="100px;" loading=lazy /><br /><sub><b>Gusted</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=Gusted" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/redoomed1"><img src="https://avatars.githubusercontent.com/u/161974310?v=4" width="100px;" loading=lazy /><br /><sub><b>redoomed1</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/pulls?q=is%3Apr+reviewed-by%3Aredoomed1" title="Reviewed Pull Requests">👀</a> <a href="https://github.com/privacyguides/privacyguides.org/commits?author=redoomed1" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/Offpics"><img src="https://avatars.githubusercontent.com/u/20701635?v=4" width="100px;" loading=lazy /><br /><sub><b>Offpics</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=Offpics" title="Documentation">📖</a></td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/kimg45"><img src="https://avatars.githubusercontent.com/u/138676274?v=4" width="100px;" loading=lazy /><br /><sub><b>kimg45</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=kimg45" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/djoate"><img src="https://avatars.githubusercontent.com/u/56777051?v=4" width="100px;" loading=lazy /><br /><sub><b>djoate</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=djoate" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/afighttilldeath"><img src="https://avatars.githubusercontent.com/u/29437578?v=4" width="100px;" loading=lazy /><br /><sub><b>afighttilldeath</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=afighttilldeath" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/paulverbeke"><img src="https://avatars.githubusercontent.com/u/6412153?v=4" width="100px;" loading=lazy /><br /><sub><b>Paul Verbeke</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=paulverbeke" title="Documentation">📖</a> <a href="#translation-paulverbeke" title="Translation">🌍</a> <a href="https://github.com/privacyguides/privacyguides.org/issues?q=author%3Apaulverbeke" title="Bug reports">🐛</a> <a href="#mentoring-paulverbeke" title="Mentoring">🧑🏫</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://mitchellcash.com/"><img src="https://avatars.githubusercontent.com/u/8009243?v=4" width="100px;" loading=lazy /><br /><sub><b>Mitchell Cash</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=MitchellCash" title="Documentation">📖</a></td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/NeverDucky"><img src="https://avatars.githubusercontent.com/u/32468662?v=4" width="100px;" loading=lazy /><br /><sub><b>NeverDucky</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=NeverDucky" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/efb4f5ff-1298-471a-8973-3d47447115dc"><img src="https://avatars.githubusercontent.com/u/73130443?v=4" width="100px;" loading=lazy /><br /><sub><b>efb4f5ff-1298-471a-8973-3d47447115dc</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=efb4f5ff-1298-471a-8973-3d47447115dc" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://www.giga.uliege.be/cms/c_4113283/en/giga-directory?uid=u225986"><img src="https://avatars.githubusercontent.com/u/1118942?v=4" width="100px;" loading=lazy /><br /><sub><b>Stephen Karl Larroque</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=lrq3000" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/0rdinant"><img src="https://avatars.githubusercontent.com/u/76827384?v=4" width="100px;" loading=lazy /><br /><sub><b>0rdinant</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=0rdinant" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/Zenithium"><img src="https://avatars.githubusercontent.com/u/48525551?v=4" width="100px;" loading=lazy /><br /><sub><b>Zenithium</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=Zenithium" title="Documentation">📖</a></td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="http://www.ravellaw.com/"><img src="https://avatars.githubusercontent.com/u/860471?v=4" width="100px;" loading=lazy /><br /><sub><b>Jordan Gwyn</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=emanresusername" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://gururaja.in/"><img src="https://avatars.githubusercontent.com/u/70903440?v=4" width="100px;" loading=lazy /><br /><sub><b>Guru</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=Guru-25" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/datoshkr"><img src="https://avatars.githubusercontent.com/u/79659024?v=4" width="100px;" loading=lazy /><br /><sub><b>datoshkr</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=datoshkr" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/Kcchouette"><img src="https://avatars.githubusercontent.com/u/3000936?v=4" width="100px;" loading=lazy /><br /><sub><b>Kcchouette</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=Kcchouette" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://jacobneplokh.com/"><img src="https://avatars.githubusercontent.com/u/46184597?v=4" width="100px;" loading=lazy /><br /><sub><b>Jacob Neplokh</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=jneplokh" title="Documentation">📖</a></td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/razac-elda"><img src="https://avatars.githubusercontent.com/u/30749146?v=4" width="100px;" loading=lazy /><br /><sub><b>Leonardo Mazzon</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=razac-elda" title="Documentation">📖</a> <a href="https://github.com/privacyguides/privacyguides.org/issues?q=author%3Arazac-elda" title="Bug reports">🐛</a> <a href="#financial-razac-elda" title="Financial">💵</a> <a href="#promotion-razac-elda" title="Promotion">📣</a> <a href="#question-razac-elda" title="Answering Questions">💬</a> <a href="#translation-razac-elda" title="Translation">🌍</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/opheron"><img src="https://avatars.githubusercontent.com/u/7110152?v=4" width="100px;" loading=lazy /><br /><sub><b>Andrew Chong</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=opheron" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/woctezuma"><img src="https://avatars.githubusercontent.com/u/570669?v=4" width="100px;" loading=lazy /><br /><sub><b>Wok</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=woctezuma" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://itsnothing.net/"><img src="https://avatars.githubusercontent.com/u/105246487?v=4" width="100px;" loading=lazy /><br /><sub><b>nopeitsnothing</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=nopeitsnothing" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://lynn.one/"><img src="https://avatars.githubusercontent.com/u/63118982?v=4" width="100px;" loading=lazy /><br /><sub><b>Lynn Stephenson</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=lynn-stephenson" title="Documentation">📖</a></td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://cory.solovewi.cz/"><img src="https://avatars.githubusercontent.com/u/19578733?v=4" width="100px;" loading=lazy /><br /><sub><b>Cory Solovewicz</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=corysolovewicz" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://zerolimits.dev/"><img src="https://avatars.githubusercontent.com/u/103803129?v=4" width="100px;" loading=lazy /><br /><sub><b>noClaps</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=noClaps" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/Perelandra0x309"><img src="https://avatars.githubusercontent.com/u/22124003?v=4" width="100px;" loading=lazy /><br /><sub><b>Brian</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=Perelandra0x309" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/SkewedZeppelin"><img src="https://avatars.githubusercontent.com/u/8296104?v=4" width="100px;" loading=lazy /><br /><sub><b>SkewedZeppelin</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=SkewedZeppelin" title="Documentation">📖</a> <a href="#question-SkewedZeppelin" title="Answering Questions">💬</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/Arcadius3D"><img src="https://avatars.githubusercontent.com/u/165268515?v=4" width="100px;" loading=lazy /><br /><sub><b>Arcadius3D</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=Arcadius3D" title="Documentation">📖</a></td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/vpnarea"><img src="https://avatars.githubusercontent.com/u/17130812?v=4" width="100px;" loading=lazy /><br /><sub><b>vpnarea</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=vpnarea" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://namazso.eu/"><img src="https://avatars.githubusercontent.com/u/8676443?v=4" width="100px;" loading=lazy /><br /><sub><b>namazso</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=namazso" title="Documentation">📖</a> <a href="#question-namazso" title="Answering Questions">💬</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/cYDN48"><img src="https://avatars.githubusercontent.com/u/96789053?v=4" width="100px;" loading=lazy /><br /><sub><b>cYDN48</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=cYDN48" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/gjhklfdsa"><img src="https://avatars.githubusercontent.com/u/45323745?v=4" width="100px;" loading=lazy /><br /><sub><b>gjhklfdsa</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=gjhklfdsa" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://fxgn.dev/"><img src="https://avatars.githubusercontent.com/u/66178592?v=4" width="100px;" loading=lazy /><br /><sub><b>Pavel Zolotarevskiy</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=flexagoon" title="Documentation">📖</a></td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://www.mediawiki.org/wiki/User:Quiddity"><img src="https://avatars.githubusercontent.com/u/6633202?v=4" width="100px;" loading=lazy /><br /><sub><b>quiddity-wp</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=quiddity-wp" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://nikhiljha.com/"><img src="https://avatars.githubusercontent.com/u/2773700?v=4" width="100px;" loading=lazy /><br /><sub><b>Nikhil Jha</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=nikhiljha" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/subatomic-honda-civic"><img src="https://avatars.githubusercontent.com/u/105336176?v=4" width="100px;" loading=lazy /><br /><sub><b>Subatomic Honda Civic</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=subatomic-honda-civic" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/ticklemyIP"><img src="https://avatars.githubusercontent.com/u/126688461?v=4" width="100px;" loading=lazy /><br /><sub><b>ticklemyIP</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=ticklemyIP" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/jermanuts"><img src="https://avatars.githubusercontent.com/u/109705802?v=4" width="100px;" loading=lazy /><br /><sub><b>jermanuts</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=jermanuts" title="Documentation">📖</a></td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/conorohiggins"><img src="https://avatars.githubusercontent.com/u/16993660?v=4" width="100px;" loading=lazy /><br /><sub><b>conorohiggins</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=conorohiggins" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/TechFanTheo"><img src="https://avatars.githubusercontent.com/u/78900789?v=4" width="100px;" loading=lazy /><br /><sub><b>TechFanTheo</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=TechFanTheo" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/r-j-taylor"><img src="https://avatars.githubusercontent.com/u/35360143?v=4" width="100px;" loading=lazy /><br /><sub><b>Ryan Taylor</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=r-j-taylor" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/Positron832"><img src="https://avatars.githubusercontent.com/u/72881516?v=4" width="100px;" loading=lazy /><br /><sub><b>Positron832</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=Positron832" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/JustLuckNoSkill"><img src="https://avatars.githubusercontent.com/u/114787000?v=4" width="100px;" loading=lazy /><br /><sub><b>JustLuckNoSkill</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=JustLuckNoSkill" title="Documentation">📖</a></td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/Akyshnik"><img src="https://avatars.githubusercontent.com/u/23380632?v=4" width="100px;" loading=lazy /><br /><sub><b>Arkadiy</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=Akyshnik" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/jackmchou"><img src="https://avatars.githubusercontent.com/u/56708167?v=4" width="100px;" loading=lazy /><br /><sub><b>Jack Chou</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=jackmchou" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://ave.zone/"><img src="https://avatars.githubusercontent.com/u/6755762?v=4" width="100px;" loading=lazy /><br /><sub><b>ave</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=aveao" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/Booteille"><img src="https://avatars.githubusercontent.com/u/2203721?v=4" width="100px;" loading=lazy /><br /><sub><b>Boo</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=Booteille" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/IDKwhattoputhere"><img src="https://avatars.githubusercontent.com/u/39969358?v=4" width="100px;" loading=lazy /><br /><sub><b>IDKwhattoputhere</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=IDKwhattoputhere" title="Documentation">📖</a></td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/idk-r-n"><img src="https://avatars.githubusercontent.com/u/111711873?v=4" width="100px;" loading=lazy /><br /><sub><b>idkrn</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=idk-r-n" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/ggg27"><img src="https://avatars.githubusercontent.com/u/52841257?v=4" width="100px;" loading=lazy /><br /><sub><b>ggg27</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=ggg27" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/WalterKlosse"><img src="https://avatars.githubusercontent.com/u/27290800?v=4" width="100px;" loading=lazy /><br /><sub><b>WalterKlosse</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=WalterKlosse" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://stosb.com/"><img src="https://avatars.githubusercontent.com/u/108670?v=4" width="100px;" loading=lazy /><br /><sub><b>Tom Hacohen</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=tasn" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://www.linkedin.com/in/paulfeuvraux/"><img src="https://avatars.githubusercontent.com/u/13090164?v=4" width="100px;" loading=lazy /><br /><sub><b>Paul Feuvraux</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=Super-Baleine" title="Documentation">📖</a></td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="http://sbennett1990.github.io/Resume/"><img src="https://avatars.githubusercontent.com/u/6392550?v=4" width="100px;" loading=lazy /><br /><sub><b>Scott Bennett</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=sbennett1990" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="http://blog.191.161.xyz/"><img src="https://avatars.githubusercontent.com/u/1544371?v=4" width="100px;" loading=lazy /><br /><sub><b>Federico Ariel Castagnini</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=facastagnini" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/jslawler-gh"><img src="https://avatars.githubusercontent.com/u/149243371?v=4" width="100px;" loading=lazy /><br /><sub><b>jslawler-gh</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=jslawler-gh" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/spaceoden"><img src="https://avatars.githubusercontent.com/u/26421479?v=4" width="100px;" loading=lazy /><br /><sub><b>spaceoden</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=spaceoden" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/xe-3"><img src="https://avatars.githubusercontent.com/u/137224605?v=4" width="100px;" loading=lazy /><br /><sub><b>xe3</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=xe-3" title="Documentation">📖</a></td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/anoadragon453"><img src="https://avatars.githubusercontent.com/u/1342360?v=4" width="100px;" loading=lazy /><br /><sub><b>Andrew Morgan</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=anoadragon453" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://rossviewef.org/"><img src="https://avatars.githubusercontent.com/u/35670796?v=4" width="100px;" loading=lazy /><br /><sub><b>Caleb King</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=EvasivePangolin" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/Eduardo06sp"><img src="https://avatars.githubusercontent.com/u/34868791?v=4" width="100px;" loading=lazy /><br /><sub><b>Eduardo</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=Eduardo06sp" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/NafeezJS"><img src="https://avatars.githubusercontent.com/u/17627305?v=4" width="100px;" loading=lazy /><br /><sub><b>NafeezJS</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=NafeezJS" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/Sloofy"><img src="https://avatars.githubusercontent.com/u/18003771?v=4" width="100px;" loading=lazy /><br /><sub><b>Sloofy</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=Sloofy" title="Documentation">📖</a></td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://sts10.github.io/"><img src="https://avatars.githubusercontent.com/u/4871664?v=4" width="100px;" loading=lazy /><br /><sub><b>Sam Schlinkert</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=sts10" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/gaborluk"><img src="https://avatars.githubusercontent.com/u/6388299?v=4" width="100px;" loading=lazy /><br /><sub><b>Gabor Luk</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=gaborluk" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://deiaspie.github.io/"><img src="https://avatars.githubusercontent.com/u/93835541?v=4" width="100px;" loading=lazy /><br /><sub><b>DeiAsPie</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=DeiAsPie" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://davidetaviani.com/"><img src="https://avatars.githubusercontent.com/u/283733?v=4" width="100px;" loading=lazy /><br /><sub><b>Davide Taviani</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=Heliosmaster" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/spanishharlem"><img src="https://avatars.githubusercontent.com/u/9704046?v=4" width="100px;" loading=lazy /><br /><sub><b>spanishharlem</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=spanishharlem" title="Documentation">📖</a></td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://gonzoknows.com/"><img src="https://avatars.githubusercontent.com/u/122128828?v=4" width="100px;" loading=lazy /><br /><sub><b>Jacob Gonzales</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=jacobgonzales20" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://kaede.ch/"><img src="https://avatars.githubusercontent.com/u/74188936?v=4" width="100px;" loading=lazy /><br /><sub><b>Kaede</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=kaedech" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/abbluiz"><img src="https://avatars.githubusercontent.com/u/19765082?v=4" width="100px;" loading=lazy /><br /><sub><b>LABB</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=abbluiz" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/Raviu8"><img src="https://avatars.githubusercontent.com/u/36168047?v=4" width="100px;" loading=lazy /><br /><sub><b>Raviu8</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=Raviu8" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://www.peterdavehello.org/"><img src="https://avatars.githubusercontent.com/u/3691490?v=4" width="100px;" loading=lazy /><br /><sub><b>Peter Dave Hello</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=PeterDaveHello" title="Documentation">📖</a></td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/RoseTheFlower"><img src="https://avatars.githubusercontent.com/u/4759227?v=4" width="100px;" loading=lazy /><br /><sub><b>Rose</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=RoseTheFlower" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://xie.oskarsh.ru/"><img src="https://avatars.githubusercontent.com/u/28492051?v=4" width="100px;" loading=lazy /><br /><sub><b>Oskar Sharipov</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=igoose1" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://samuellucas.com/"><img src="https://avatars.githubusercontent.com/u/63159663?v=4" width="100px;" loading=lazy /><br /><sub><b>Samuel Lucas</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=samuel-lucas6" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/NylaTheWolf"><img src="https://avatars.githubusercontent.com/u/41797151?v=4" width="100px;" loading=lazy /><br /><sub><b>NylaTheWolf</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=NylaTheWolf" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://matthewdavis.me/"><img src="https://avatars.githubusercontent.com/u/298426?v=4" width="100px;" loading=lazy /><br /><sub><b>Matthew Davis</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=matthewdavis" title="Documentation">📖</a></td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://mpc.sh/"><img src="https://avatars.githubusercontent.com/u/2894019?v=4" width="100px;" loading=lazy /><br /><sub><b>Mark Cohen</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=mpcsh" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/madscientist16"><img src="https://avatars.githubusercontent.com/u/67949699?v=4" width="100px;" loading=lazy /><br /><sub><b>Mad Scientist</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=madscientist16" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/mmvanheusden"><img src="https://avatars.githubusercontent.com/u/50550545?v=4" width="100px;" loading=lazy /><br /><sub><b>Maarten</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=mmvanheusden" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://awesomesheep48.ca/"><img src="https://avatars.githubusercontent.com/u/58151048?v=4" width="100px;" loading=lazy /><br /><sub><b>William Davis</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=unbeatable-101" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/WayTooWill"><img src="https://avatars.githubusercontent.com/u/119883899?v=4" width="100px;" loading=lazy /><br /><sub><b>William Thomas Wilkins</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=WayTooWill" title="Documentation">📖</a></td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/oXyiGYJ"><img src="https://avatars.githubusercontent.com/u/617189?v=4" width="100px;" loading=lazy /><br /><sub><b>wylel</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=oXyiGYJ" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://willbrowning.me/"><img src="https://avatars.githubusercontent.com/u/20662079?v=4" width="100px;" loading=lazy /><br /><sub><b>Will Browning</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=willbrowningme" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://ycao.top/"><img src="https://avatars.githubusercontent.com/u/32544798?v=4" width="100px;" loading=lazy /><br /><sub><b>Yi Cao</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=xiaoyu2006" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/yusufdaglioglu"><img src="https://avatars.githubusercontent.com/u/90555550?v=4" width="100px;" loading=lazy /><br /><sub><b>Yusuf Daglioglu</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=yusufdaglioglu" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/Zackaryia"><img src="https://avatars.githubusercontent.com/u/30780411?v=4" width="100px;" loading=lazy /><br /><sub><b>Zack</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=Zackaryia" title="Documentation">📖</a></td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://zhw.pages.dev/"><img src="https://avatars.githubusercontent.com/u/14029004?v=4" width="100px;" loading=lazy /><br /><sub><b>ZH王</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=wi24rd" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://cryptography.dog/"><img src="https://avatars.githubusercontent.com/u/1264398?v=4" width="100px;" loading=lazy /><br /><sub><b>ansuz</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=ansuz" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://codeberg.org/archeite"><img src="https://avatars.githubusercontent.com/u/121004047?v=4" width="100px;" loading=lazy /><br /><sub><b>archeite</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=archeite" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/asdfghjz"><img src="https://avatars.githubusercontent.com/u/42332644?v=4" width="100px;" loading=lazy /><br /><sub><b>asdfghjz</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=asdfghjz" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/ayaen"><img src="https://avatars.githubusercontent.com/u/96900168?v=4" width="100px;" loading=lazy /><br /><sub><b>ayaen</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=ayaen" title="Documentation">📖</a></td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/b-harper"><img src="https://avatars.githubusercontent.com/u/3729684?v=4" width="100px;" loading=lazy /><br /><sub><b>b-harper</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=b-harper" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://verybadfrags.com/"><img src="https://avatars.githubusercontent.com/u/1664052?v=4" width="100px;" loading=lazy /><br /><sub><b>Loic Vourch</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=VeryBadFrags" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/crasm"><img src="https://avatars.githubusercontent.com/u/16730716?v=4" width="100px;" loading=lazy /><br /><sub><b>crasm</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=crasm" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/eagerto-learn"><img src="https://avatars.githubusercontent.com/u/51919789?v=4" width="100px;" loading=lazy /><br /><sub><b>eagerto-learn</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=eagerto-learn" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/egecelikci"><img src="https://avatars.githubusercontent.com/u/30394812?v=4" width="100px;" loading=lazy /><br /><sub><b>egecelikci</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=egecelikci" title="Documentation">📖</a></td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/elleybean"><img src="https://avatars.githubusercontent.com/u/37009392?v=4" width="100px;" loading=lazy /><br /><sub><b>elleybean</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=elleybean" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/ferothefox"><img src="https://avatars.githubusercontent.com/u/52982404?v=4" width="100px;" loading=lazy /><br /><sub><b>Evan Song</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=ferothefox" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/pynixis"><img src="https://avatars.githubusercontent.com/u/5612336?v=4" width="100px;" loading=lazy /><br /><sub><b>pynixis</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=pynixis" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://seirdy.one/"><img src="https://avatars.githubusercontent.com/u/44756978?v=4" width="100px;" loading=lazy /><br /><sub><b>Seirdy</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=Seirdy" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/NPN"><img src="https://avatars.githubusercontent.com/u/1497826?v=4" width="100px;" loading=lazy /><br /><sub><b>Ryan Huang</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=NPN" title="Documentation">📖</a></td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/chickahoona"><img src="https://avatars.githubusercontent.com/u/8075146?v=4" width="100px;" loading=lazy /><br /><sub><b>Sascha P.</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=chickahoona" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/Securified"><img src="https://avatars.githubusercontent.com/u/79296234?v=4" width="100px;" loading=lazy /><br /><sub><b>Securified</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=Securified" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://sy.mk/"><img src="https://avatars.githubusercontent.com/u/18217335?v=4" width="100px;" loading=lazy /><br /><sub><b>Sergey Musiyenko</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=musiyenko" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/Spydar007"><img src="https://avatars.githubusercontent.com/u/7336943?v=4" width="100px;" loading=lazy /><br /><sub><b>Spydar007</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=Spydar007" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/shbach"><img src="https://avatars.githubusercontent.com/u/5298745?v=4" width="100px;" loading=lazy /><br /><sub><b>Steven Bach</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=shbach" title="Documentation">📖</a></td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/sjlehn"><img src="https://avatars.githubusercontent.com/u/6686486?v=4" width="100px;" loading=lazy /><br /><sub><b>Steven Lehn</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=sjlehn" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://steven.vandegraaf.xyz/"><img src="https://avatars.githubusercontent.com/u/8904453?v=4" width="100px;" loading=lazy /><br /><sub><b>Steven van de Graaf</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=sgraaf" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://skortekaas.nl/"><img src="https://avatars.githubusercontent.com/u/6728108?v=4" width="100px;" loading=lazy /><br /><sub><b>Sven Kortekaas</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=SvenKortekaas" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://tejasgupta.com/"><img src="https://avatars.githubusercontent.com/u/18518375?v=4" width="100px;" loading=lazy /><br /><sub><b>Tejas Gupta</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=TGNYC" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/tebowy"><img src="https://avatars.githubusercontent.com/u/3144357?v=4" width="100px;" loading=lazy /><br /><sub><b>Tebowy Seba</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=tebowy" title="Documentation">📖</a></td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://tedgravlin.tech/"><img src="https://avatars.githubusercontent.com/u/123981212?v=4" width="100px;" loading=lazy /><br /><sub><b>Ted Gravlin</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=tedgravlin" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://thefrenchghosty.me/"><img src="https://avatars.githubusercontent.com/u/47571719?v=4" width="100px;" loading=lazy /><br /><sub><b>TheFrenchGhosty</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=TheFrenchGhosty" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/TheNoobWar"><img src="https://avatars.githubusercontent.com/u/1857590?v=4" width="100px;" loading=lazy /><br /><sub><b>TheNoobWar</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=TheNoobWar" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://git.synz.io/users/Synzvato/projects#most-recent-activity"><img src="https://avatars.githubusercontent.com/u/2366020?v=4" width="100px;" loading=lazy /><br /><sub><b>Thomas Rientjes</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=Synzvato" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/vergenzt"><img src="https://avatars.githubusercontent.com/u/1725615?v=4" width="100px;" loading=lazy /><br /><sub><b>Tim Vergenz</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=vergenzt" title="Documentation">📖</a></td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/tommyent"><img src="https://avatars.githubusercontent.com/u/509970?v=4" width="100px;" loading=lazy /><br /><sub><b>Tom Sullivan</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=tommyent" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/tonyztan"><img src="https://avatars.githubusercontent.com/u/2025495?v=4" width="100px;" loading=lazy /><br /><sub><b>Tony Tan</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=tonyztan" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/TroubleDog54"><img src="https://avatars.githubusercontent.com/u/115918107?v=4" width="100px;" loading=lazy /><br /><sub><b>TroubleDog54</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=TroubleDog54" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/User486375"><img src="https://avatars.githubusercontent.com/u/30012923?v=4" width="100px;" loading=lazy /><br /><sub><b>User486375</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=User486375" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/nchristensen"><img src="https://avatars.githubusercontent.com/u/11543181?v=4" width="100px;" loading=lazy /><br /><sub><b>Nicholas Christensen</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=nchristensen" title="Documentation">📖</a></td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/oppressor1761"><img src="https://avatars.githubusercontent.com/u/163018825?v=4" width="100px;" loading=lazy /><br /><sub><b>oppressor1761</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=oppressor1761" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/pbbob"><img src="https://avatars.githubusercontent.com/u/34972102?v=4" width="100px;" loading=lazy /><br /><sub><b>pbbob</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=pbbob" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/pdjpdjpdj"><img src="https://avatars.githubusercontent.com/u/47047080?v=4" width="100px;" loading=lazy /><br /><sub><b>pdjpdjpdj</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=pdjpdjpdj" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/ph00lt0"><img src="https://avatars.githubusercontent.com/u/15004290?v=4" width="100px;" loading=lazy /><br /><sub><b>Stella Polaris</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=ph00lt0" title="Documentation">📖</a> <a href="#research-ph00lt0" title="Research">🔬</a> <a href="#promotion-ph00lt0" title="Promotion">📣</a> <a href="#question-ph00lt0" title="Answering Questions">💬</a> <a href="https://github.com/privacyguides/privacyguides.org/pulls?q=is%3Apr+reviewed-by%3Aph00lt0" title="Reviewed Pull Requests">👀</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/regaldude"><img src="https://avatars.githubusercontent.com/u/63294824?v=4" width="100px;" loading=lazy /><br /><sub><b>regaldude</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=regaldude" title="Documentation">📖</a></td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/rusty-snake"><img src="https://avatars.githubusercontent.com/u/41237666?v=4" width="100px;" loading=lazy /><br /><sub><b>rusty-snake</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=rusty-snake" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/sachk"><img src="https://avatars.githubusercontent.com/u/10218019?v=4" width="100px;" loading=lazy /><br /><sub><b>sacha</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=sachk" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/schwukas"><img src="https://avatars.githubusercontent.com/u/33559975?v=4" width="100px;" loading=lazy /><br /><sub><b>schwukas</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=schwukas" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/sh-dv"><img src="https://avatars.githubusercontent.com/u/44544201?v=4" width="100px;" loading=lazy /><br /><sub><b>sh-dv</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=sh-dv" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/szTheory"><img src="https://avatars.githubusercontent.com/u/28652?v=4" width="100px;" loading=lazy /><br /><sub><b>szTheory</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=szTheory" title="Documentation">📖</a></td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/tbds"><img src="https://avatars.githubusercontent.com/u/32208649?v=4" width="100px;" loading=lazy /><br /><sub><b>Thunderbolt Digital</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=tbds" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/theRhinoLogician"><img src="https://avatars.githubusercontent.com/u/8325899?v=4" width="100px;" loading=lazy /><br /><sub><b>E. S. Leonesco</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=theRhinoLogician" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/titanism"><img src="https://avatars.githubusercontent.com/u/101466223?v=4" width="100px;" loading=lazy /><br /><sub><b>titanism</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=titanism" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/tomac4t"><img src="https://avatars.githubusercontent.com/u/47532693?v=4" width="100px;" loading=lazy /><br /><sub><b>tomac4t</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=tomac4t" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://virustotalop.github.io/"><img src="https://avatars.githubusercontent.com/u/11567285?v=4" width="100px;" loading=lazy /><br /><sub><b>virustotalop</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=virustotalop" title="Documentation">📖</a></td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://unit2.ca/"><img src="https://avatars.githubusercontent.com/u/4949200?v=4" width="100px;" loading=lazy /><br /><sub><b>wintr</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=wintr-" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/xelarate86"><img src="https://avatars.githubusercontent.com/u/14865038?v=4" width="100px;" loading=lazy /><br /><sub><b>xelarate86</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=xelarate86" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/yeoneer"><img src="https://avatars.githubusercontent.com/u/84702275?v=4" width="100px;" loading=lazy /><br /><sub><b>yeoneer</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=yeoneer" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://foxt.dev/"><img src="https://avatars.githubusercontent.com/u/12257112?v=4" width="100px;" loading=lazy /><br /><sub><b>foxt</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=foxt" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/fredster33"><img src="https://avatars.githubusercontent.com/u/64927044?v=4" width="100px;" loading=lazy /><br /><sub><b>Freddie</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=fredster33" title="Documentation">📖</a></td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/ghbjklhv"><img src="https://avatars.githubusercontent.com/u/50426427?v=4" width="100px;" loading=lazy /><br /><sub><b>ghbjklhv</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=ghbjklhv" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/gorhill"><img src="https://avatars.githubusercontent.com/u/585534?v=4" width="100px;" loading=lazy /><br /><sub><b>Raymond Hill</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=gorhill" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://groovecoder.com/"><img src="https://avatars.githubusercontent.com/u/71928?v=4" width="100px;" loading=lazy /><br /><sub><b>luke crouch</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=groovecoder" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/fd1f"><img src="https://avatars.githubusercontent.com/u/30058021?v=4" width="100px;" loading=lazy /><br /><sub><b>fd1f744993de14178e6c</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=fd1f" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/habitualname"><img src="https://avatars.githubusercontent.com/u/101975345?v=4" width="100px;" loading=lazy /><br /><sub><b>habitualname</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=habitualname" title="Documentation">📖</a></td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/hook321"><img src="https://avatars.githubusercontent.com/u/7744057?v=4" width="100px;" loading=lazy /><br /><sub><b>hook</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=hook321" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://jfa.sh/"><img src="https://avatars.githubusercontent.com/u/6962524?v=4" width="100px;" loading=lazy /><br /><sub><b>nein</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=jfabraxas" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/jkhgvfgvsth"><img src="https://avatars.githubusercontent.com/u/52437244?v=4" width="100px;" loading=lazy /><br /><sub><b>jkhgvfgvsth</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=jkhgvfgvsth" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/joaonsg"><img src="https://avatars.githubusercontent.com/u/8725806?v=4" width="100px;" loading=lazy /><br /><sub><b>joaonsg</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=joaonsg" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://www.ivpn.net/"><img src="https://avatars.githubusercontent.com/u/60918126?v=4" width="100px;" loading=lazy /><br /><sub><b>johnnyburnaway</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=johnnyburnaway" title="Documentation">📖</a></td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/jus9"><img src="https://avatars.githubusercontent.com/u/72120996?v=4" width="100px;" loading=lazy /><br /><sub><b>jus9</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=jus9" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/kc1212"><img src="https://avatars.githubusercontent.com/u/1093806?v=4" width="100px;" loading=lazy /><br /><sub><b>kc1212</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=kc1212" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/kryptish"><img src="https://avatars.githubusercontent.com/u/39660724?v=4" width="100px;" loading=lazy /><br /><sub><b>kryptish</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=kryptish" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/m3t/id"><img src="https://avatars.githubusercontent.com/u/12968867?v=4" width="100px;" loading=lazy /><br /><sub><b>m3t</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=m3t" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/macau23"><img src="https://avatars.githubusercontent.com/u/31501455?v=4" width="100px;" loading=lazy /><br /><sub><b>macau23</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=macau23" title="Documentation">📖</a></td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/mat1th"><img src="https://avatars.githubusercontent.com/u/6486389?v=4" width="100px;" loading=lazy /><br /><sub><b>mat1th</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=mat1th" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/mwmcode"><img src="https://avatars.githubusercontent.com/u/13101565?v=4" width="100px;" loading=lazy /><br /><sub><b>MWM</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=mwmcode" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/michaelplews"><img src="https://avatars.githubusercontent.com/u/14098929?v=4" width="100px;" loading=lazy /><br /><sub><b>Michael Plews</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=michaelplews" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/moritztk"><img src="https://avatars.githubusercontent.com/u/36471066?v=4" width="100px;" loading=lazy /><br /><sub><b>moritztk</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=moritztk" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://aaronhorler.com/"><img src="https://avatars.githubusercontent.com/u/13065365?v=4" width="100px;" loading=lazy /><br /><sub><b>Aaron Horler</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=aghorler" title="Documentation">📖</a></td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/Commenter25"><img src="https://avatars.githubusercontent.com/u/35016761?v=4" width="100px;" loading=lazy /><br /><sub><b>Commenter</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=Commenter25" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://blog.laubacher.io/"><img src="https://avatars.githubusercontent.com/u/12443257?v=4" width="100px;" loading=lazy /><br /><sub><b>Cédric Laubacher</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=Starbix" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://gitlab.com/dpeukert"><img src="https://avatars.githubusercontent.com/u/3451904?v=4" width="100px;" loading=lazy /><br /><sub><b>Daniel Peukert</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=dpeukert" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/dabreese00"><img src="https://avatars.githubusercontent.com/u/5170955?v=4" width="100px;" loading=lazy /><br /><sub><b>David Breese</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=dabreese00" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="http://www.dimitrisapostolou.com/"><img src="https://avatars.githubusercontent.com/u/227442?v=4" width="100px;" loading=lazy /><br /><sub><b>Dimitris Apostolou</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=rex4539" title="Documentation">📖</a></td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/Dyrimon"><img src="https://avatars.githubusercontent.com/u/77260451?v=4" width="100px;" loading=lazy /><br /><sub><b>Dyrimon</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=Dyrimon" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/IkelAtomig"><img src="https://avatars.githubusercontent.com/u/101938856?v=4" width="100px;" loading=lazy /><br /><sub><b>Ikel Atomig</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=IkelAtomig" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://www.eliasojala.me/contact/"><img src="https://avatars.githubusercontent.com/u/5832930?v=4" width="100px;" loading=lazy /><br /><sub><b>Elias Ojala</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=theel0ja" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/feni-brian"><img src="https://avatars.githubusercontent.com/u/56452538?v=4" width="100px;" loading=lazy /><br /><sub><b>Feni Brian</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=feni-brian" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://www.filips.si/"><img src="https://avatars.githubusercontent.com/u/16626308?v=4" width="100px;" loading=lazy /><br /><sub><b>Filip Š</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=filips123" title="Documentation">📖</a></td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/FlxAlbroscheit"><img src="https://avatars.githubusercontent.com/u/2439195?v=4" width="100px;" loading=lazy /><br /><sub><b>Felix Albroscheit</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=FlxAlbroscheit" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/GReagle"><img src="https://avatars.githubusercontent.com/u/11979774?v=4" width="100px;" loading=lazy /><br /><sub><b>GReagle</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=GReagle" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/xPMo"><img src="https://avatars.githubusercontent.com/u/16061366?v=4" width="100px;" loading=lazy /><br /><sub><b>Gamma</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=xPMo" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/GetBoz"><img src="https://avatars.githubusercontent.com/u/8277114?v=4" width="100px;" loading=lazy /><br /><sub><b>GetBoz</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=GetBoz" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/GrimPixel"><img src="https://avatars.githubusercontent.com/u/39795763?v=4" width="100px;" loading=lazy /><br /><sub><b>GrimPixel</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=GrimPixel" title="Documentation">📖</a></td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/Alonely0"><img src="https://avatars.githubusercontent.com/u/59423215?v=4" width="100px;" loading=lazy /><br /><sub><b>Guillem L. Jara</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=Alonely0" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/HxxxxxS"><img src="https://avatars.githubusercontent.com/u/4034517?v=4" width="100px;" loading=lazy /><br /><sub><b>HxxxxxS</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=HxxxxxS" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/himanshuchandola-zz"><img src="https://avatars.githubusercontent.com/u/34373537?v=4" width="100px;" loading=lazy /><br /><sub><b>Himanshu Chandola</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=himanshuchandola-zz" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/concatime"><img src="https://avatars.githubusercontent.com/u/26262387?v=4" width="100px;" loading=lazy /><br /><sub><b>Issam Maghni</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=concatime" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/ItsDonny"><img src="https://avatars.githubusercontent.com/u/96709134?v=4" width="100px;" loading=lazy /><br /><sub><b>ItsDonny</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=ItsDonny" title="Documentation">📖</a></td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/thecodrr"><img src="https://avatars.githubusercontent.com/u/7473959?v=4" width="100px;" loading=lazy /><br /><sub><b>Abdullah Atta</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=thecodrr" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/adam-sroka"><img src="https://avatars.githubusercontent.com/u/45038919?v=4" width="100px;" loading=lazy /><br /><sub><b>Adam Sroka</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=adam-sroka" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/criadoperez"><img src="https://avatars.githubusercontent.com/u/8580472?v=4" width="100px;" loading=lazy /><br /><sub><b>criadoperez</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=criadoperez" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="http://stingle.org/"><img src="https://avatars.githubusercontent.com/u/149764?v=4" width="100px;" loading=lazy /><br /><sub><b>Alex Amiryan</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=alexamiryan" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/alexshoup"><img src="https://avatars.githubusercontent.com/u/24282323?v=4" width="100px;" loading=lazy /><br /><sub><b>Alex Shoup</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=alexshoup" title="Documentation">📖</a></td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://alex.lol/"><img src="https://avatars.githubusercontent.com/u/1346090?v=4" width="100px;" loading=lazy /><br /><sub><b>Alex Thomassen</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=Decicus" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://secluded.site/"><img src="https://avatars.githubusercontent.com/u/29460675?v=4" width="100px;" loading=lazy /><br /><sub><b>Amolith</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=Amolith" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://scarpino.dev/"><img src="https://avatars.githubusercontent.com/u/529436?v=4" width="100px;" loading=lazy /><br /><sub><b>Andrea Scarpino</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=ilpianista" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://noplanman.ch/"><img src="https://avatars.githubusercontent.com/u/9423417?v=4" width="100px;" loading=lazy /><br /><sub><b>Armando Lüscher</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=noplanman" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/AshTex"><img src="https://avatars.githubusercontent.com/u/11602677?v=4" width="100px;" loading=lazy /><br /><sub><b>Ash T</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=AshTex" title="Documentation">📖</a></td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/4-FLOSS-Free-Libre-Open-Source-Software"><img src="https://avatars.githubusercontent.com/u/46166740?v=4" width="100px;" loading=lazy /><br /><sub><b>Bernd Eichelberger</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=4-FLOSS-Free-Libre-Open-Source-Software" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/BionicBison05"><img src="https://avatars.githubusercontent.com/u/93722725?v=4" width="100px;" loading=lazy /><br /><sub><b>BionicBison05</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=BionicBison05" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://brentgervais.com/"><img src="https://avatars.githubusercontent.com/u/7018928?v=4" width="100px;" loading=lazy /><br /><sub><b>Brent Gervais</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=gerbrent" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://brian-cooper.com/"><img src="https://avatars.githubusercontent.com/u/20056195?v=4" width="100px;" loading=lazy /><br /><sub><b>Brian Cooper</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=coopbri" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/Caboose700"><img src="https://avatars.githubusercontent.com/u/10017396?v=4" width="100px;" loading=lazy /><br /><sub><b>Caboose700</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=Caboose700" title="Documentation">📖</a></td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://www.cadelwatson.com/"><img src="https://avatars.githubusercontent.com/u/1031518?v=4" width="100px;" loading=lazy /><br /><sub><b>Cadel Watson</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=kdelwat" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/trosel"><img src="https://avatars.githubusercontent.com/u/1299322?v=4" width="100px;" loading=lazy /><br /><sub><b>trosel</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=trosel" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://www.bromite.org/"><img src="https://avatars.githubusercontent.com/u/32685696?v=4" width="100px;" loading=lazy /><br /><sub><b>Carl</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=csagan5" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/Deimos"><img src="https://avatars.githubusercontent.com/u/9033?v=4" width="100px;" loading=lazy /><br /><sub><b>Chad Birch</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=Deimos" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://barry.im/"><img src="https://avatars.githubusercontent.com/u/1405770?v=4" width="100px;" loading=lazy /><br /><sub><b>Chris Barry</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=chris-barry" title="Documentation">📖</a></td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/claudiojulioferraz"><img src="https://avatars.githubusercontent.com/u/7096023?v=4" width="100px;" loading=lazy /><br /><sub><b>Júlio Ferraz</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=claudiojulioferraz" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/JackH3103"><img src="https://avatars.githubusercontent.com/u/23507259?v=4" width="100px;" loading=lazy /><br /><sub><b>Jack Hill</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=JackH3103" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/mathiazom"><img src="https://avatars.githubusercontent.com/u/24361490?v=4" width="100px;" loading=lazy /><br /><sub><b>Mathias Oterhals Myklebust</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=mathiazom" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://www.mxe.no/"><img src="https://avatars.githubusercontent.com/u/10927304?v=4" width="100px;" loading=lazy /><br /><sub><b>Mats Estensen</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=matsest" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://write.as/matt/"><img src="https://avatars.githubusercontent.com/u/1138779?v=4" width="100px;" loading=lazy /><br /><sub><b>Matt Baer</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=thebaer" title="Documentation">📖</a></td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/mehdichaouch"><img src="https://avatars.githubusercontent.com/u/861701?v=4" width="100px;" loading=lazy /><br /><sub><b>Mehdi Chaouch</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=mehdichaouch" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/mjperrone"><img src="https://avatars.githubusercontent.com/u/3848371?v=4" width="100px;" loading=lazy /><br /><sub><b>Mike Perrone</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=mjperrone" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/MitchWilkins"><img src="https://avatars.githubusercontent.com/u/17414866?v=4" width="100px;" loading=lazy /><br /><sub><b>Mitch Wilkins</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=MitchWilkins" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/moughxyz"><img src="https://avatars.githubusercontent.com/u/3277844?v=4" width="100px;" loading=lazy /><br /><sub><b>Mo</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=moughxyz" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://linderud.dev/"><img src="https://avatars.githubusercontent.com/u/1042946?v=4" width="100px;" loading=lazy /><br /><sub><b>Morten Linderud</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=Foxboron" title="Documentation">📖</a></td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/natzim"><img src="https://avatars.githubusercontent.com/u/103460227?v=4" width="100px;" loading=lazy /><br /><sub><b>natzim</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=natzim" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/Nautman"><img src="https://avatars.githubusercontent.com/u/28629647?v=4" width="100px;" loading=lazy /><br /><sub><b>Douglas</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=Nautman" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://nearwood.dev/"><img src="https://avatars.githubusercontent.com/u/1929778?v=4" width="100px;" loading=lazy /><br /><sub><b>Nick</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=nearwood" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/NielDB"><img src="https://avatars.githubusercontent.com/u/25815880?v=4" width="100px;" loading=lazy /><br /><sub><b>NielDB</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=NielDB" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://nihal-raj.github.io/"><img src="https://avatars.githubusercontent.com/u/83210067?v=4" width="100px;" loading=lazy /><br /><sub><b>Nihal Raj</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=Nihal-Raj" title="Documentation">📖</a></td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://gitlab.com/NoahGray"><img src="https://avatars.githubusercontent.com/u/3739277?v=4" width="100px;" loading=lazy /><br /><sub><b>Noah</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=OKNoah" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/n0toose"><img src="https://avatars.githubusercontent.com/u/30193966?v=4" width="100px;" loading=lazy /><br /><sub><b>Panagiotis "Ivory" Vasilopoulos</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=n0toose" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://pacr.dev/"><img src="https://avatars.githubusercontent.com/u/32212089?v=4" width="100px;" loading=lazy /><br /><sub><b>Patrick R</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=xDazld" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="http://fart.attorney/"><img src="https://avatars.githubusercontent.com/u/12037849?v=4" width="100px;" loading=lazy /><br /><sub><b>Fart Attorney</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=fartattorney" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/pilou-"><img src="https://avatars.githubusercontent.com/u/1356830?v=4" width="100px;" loading=lazy /><br /><sub><b>Pilou</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=pilou-" title="Documentation">📖</a></td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/PoorPocketsMcNewHold"><img src="https://avatars.githubusercontent.com/u/13170204?v=4" width="100px;" loading=lazy /><br /><sub><b>PoorPockets McNewHold</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=PoorPocketsMcNewHold" title="Documentation">📖</a> <a href="#translation-PoorPocketsMcNewHold" title="Translation">🌍</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/PrinceKael"><img src="https://avatars.githubusercontent.com/u/44752304?v=4" width="100px;" loading=lazy /><br /><sub><b>PrinceKael</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=PrinceKael" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://mail.protonmail.com/"><img src="https://avatars.githubusercontent.com/u/1345786?v=4" width="100px;" loading=lazy /><br /><sub><b>Richard</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=EpokK" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/walletdude"><img src="https://avatars.githubusercontent.com/u/19595856?v=4" width="100px;" loading=lazy /><br /><sub><b>Jaden Site</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=walletdude" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="http://www.jakezeal.com/"><img src="https://avatars.githubusercontent.com/u/13857938?v=4" width="100px;" loading=lazy /><br /><sub><b>Jake Zeal</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=jakezeal" title="Documentation">📖</a></td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/thatrobotdev"><img src="https://avatars.githubusercontent.com/u/18013689?v=4" width="100px;" loading=lazy /><br /><sub><b>James Kerrane</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=thatrobotdev" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/sell"><img src="https://avatars.githubusercontent.com/u/34258275?v=4" width="100px;" loading=lazy /><br /><sub><b>Sell</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=sell" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://fmbase.tw/blog/"><img src="https://avatars.githubusercontent.com/u/2720857?v=4" width="100px;" loading=lazy /><br /><sub><b>YMHuang</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=ymhuang0808" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/jonathanvansina"><img src="https://avatars.githubusercontent.com/u/25825247?v=4" width="100px;" loading=lazy /><br /><sub><b>Jonathan Vansina</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=jonathanvansina" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/jorgeluiscarrillo"><img src="https://avatars.githubusercontent.com/u/33134232?v=4" width="100px;" loading=lazy /><br /><sub><b>jorgeluiscarrillo</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=jorgeluiscarrillo" title="Documentation">📖</a></td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://julianfairfax.gitlab.io/"><img src="https://avatars.githubusercontent.com/u/43753131?v=4" width="100px;" loading=lazy /><br /><sub><b>Julian</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=julianfairfax" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/Kefaku"><img src="https://avatars.githubusercontent.com/u/114934849?v=4" width="100px;" loading=lazy /><br /><sub><b>Kefaku</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=Kefaku" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/kmgb"><img src="https://avatars.githubusercontent.com/u/25809479?v=4" width="100px;" loading=lazy /><br /><sub><b>Kevin Brennan</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=kmgb" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="http://www.kylespearrin.com/"><img src="https://avatars.githubusercontent.com/u/1190944?v=4" width="100px;" loading=lazy /><br /><sub><b>Kyle Spearrin</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=kspearrin" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://leonallen22.github.io/"><img src="https://avatars.githubusercontent.com/u/5651701?v=4" width="100px;" loading=lazy /><br /><sub><b>Leon Allen</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=leonallen22" title="Documentation">📖</a></td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/LisaWilbourn"><img src="https://avatars.githubusercontent.com/u/67932294?v=4" width="100px;" loading=lazy /><br /><sub><b>LisaWilbourn</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=LisaWilbourn" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/LordShedy"><img src="https://avatars.githubusercontent.com/u/1622827?v=4" width="100px;" loading=lazy /><br /><sub><b>Lord Shedy</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=LordShedy" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/louiswolfers"><img src="https://avatars.githubusercontent.com/u/7440721?v=4" width="100px;" loading=lazy /><br /><sub><b>Louis Wolfers</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=louiswolfers" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/lunush"><img src="https://avatars.githubusercontent.com/u/76045303?v=4" width="100px;" loading=lazy /><br /><sub><b>Lunush</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=lunush" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/mmrabbani"><img src="https://avatars.githubusercontent.com/u/56675802?v=4" width="100px;" loading=lazy /><br /><sub><b>MMR</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=mmrabbani" title="Documentation">📖</a></td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/StoppingBuck"><img src="https://avatars.githubusercontent.com/u/8426548?v=4" width="100px;" loading=lazy /><br /><sub><b>Mads Peter Rommedahl</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=StoppingBuck" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/mq1"><img src="https://avatars.githubusercontent.com/u/29694921?v=4" width="100px;" loading=lazy /><br /><sub><b>Manuel Quarneti</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=mq1" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://twitter.com/ocramleznem"><img src="https://avatars.githubusercontent.com/u/1401770?v=4" width="100px;" loading=lazy /><br /><sub><b>Marco Menzel</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=ocramleznem" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/FishCoding"><img src="https://avatars.githubusercontent.com/u/16527725?v=4" width="100px;" loading=lazy /><br /><sub><b>Mario</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=FishCoding" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://skye.sh/"><img src="https://avatars.githubusercontent.com/u/48442092?v=4" width="100px;" loading=lazy /><br /><sub><b>skye</b></sub></a><br /><a href="#question-dioxias" title="Answering Questions">💬</a></td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/r2fo"><img src="https://avatars.githubusercontent.com/u/50496756?v=4" width="100px;" loading=lazy /><br /><sub><b>r2fo</b></sub></a><br /><a href="#translation-r2fo" title="Translation">🌍</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://lamtrinh.dev/"><img src="https://avatars.githubusercontent.com/u/49742151?v=4" width="100px;" loading=lazy /><br /><sub><b>LamTrinh.Dev</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=lamtrinhdev" title="Documentation">📖</a> <a href="https://github.com/privacyguides/privacyguides.org/issues?q=author%3Alamtrinhdev" title="Bug reports">🐛</a> <a href="#question-lamtrinhdev" title="Answering Questions">💬</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://discuss.privacyguides.net/u/frostlike"><img src="https://forum-cdn.privacyguides.net/user_avatar/discuss.privacyguides.net/frostlike/288/3600_2.png" width="100px;" loading=lazy /><br /><sub><b>frostlike</b></sub></a><br /><a href="#question" title="Answering Questions">💬</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://scholz.ruhr/"><img src="https://avatars.githubusercontent.com/u/21988035?v=4" width="100px;" loading=lazy /><br /><sub><b>Merlin Scholz</b></sub></a><br /><a href="#translation-merlinscholz" title="Translation">🌍</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://jordanwarne.net/"><img src="https://avatars.githubusercontent.com/u/154663344?v=4" width="100px;" loading=lazy /><br /><sub><b>jordan warne</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=jordan-warne" title="Documentation">📖</a></td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/Dzenan"><img src="https://avatars.githubusercontent.com/u/69632324?v=4" width="100px;" loading=lazy /><br /><sub><b>Dženan</b></sub></a><br /><a href="#translation-dzenan" title="Translation">🌍</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://jxtsai.info"><img src="https://avatars.githubusercontent.com/u/8361268?v=4" width="100px;" loading=lazy /><br /><sub><b>jx tsai</b></sub></a><br /><a href="#translation-jxtsai" title="Translation">🌍</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/backstab5983"><img src="https://avatars.githubusercontent.com/u/21013752?v=4" width="100px;" loading=lazy /><br /><sub><b>backstab5983</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=backstab5983" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/antgig"><img src="https://avatars.githubusercontent.com/u/144840521?v=4" width="100px;" loading=lazy /><br /><sub><b>antgig</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=antgig" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://yzahk.in/"><img src="https://avatars.githubusercontent.com/u/604311?v=4" width="100px;" loading=lazy /><br /><sub><b>Ákos Nikházy</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=akosnikhazy" title="Documentation">📖</a></td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://fmarier.org/"><img src="https://avatars.githubusercontent.com/u/167821?v=4" width="100px;" loading=lazy /><br /><sub><b>Francois Marier</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=fmarier" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://filmsbytom.com/"><img src="https://avatars.githubusercontent.com/u/132141431?v=4" width="100px;" loading=lazy /><br /><sub><b>5-tom</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=5-tom" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/Ralphie0511"><img src="https://avatars.githubusercontent.com/u/99518791?v=4" width="100px;" loading=lazy /><br /><sub><b>Ralphie0511</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=Ralphie0511" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://kovalovs.lv/"><img src="https://avatars.githubusercontent.com/u/5563309?v=4" width="100px;" loading=lazy /><br /><sub><b>aleksejs1</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=aleksejs1" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/snwfdhmp"><img src="https://avatars.githubusercontent.com/u/23099246?v=4" width="100px;" loading=lazy /><br /><sub><b>Martin</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=snwfdhmp" title="Documentation">📖</a></td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/overwatcheddude"><img src="https://avatars.githubusercontent.com/u/37483931?v=4" width="100px;" loading=lazy /><br /><sub><b>Overwatch</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=overwatcheddude" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/m00t316"><img src="https://avatars.githubusercontent.com/u/54213179?v=4" width="100px;" loading=lazy /><br /><sub><b>Kieran Colfer</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=m00t316" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/I-I-IT"><img src="https://avatars.githubusercontent.com/u/78900789?v=4" width="100px;" loading=lazy /><br /><sub><b>Triple T</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=I-I-IT" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/IDON-TEXIST"><img src="https://avatars.githubusercontent.com/u/73442356?v=4" width="100px;" loading=lazy /><br /><sub><b>IDON-TEXIST</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=IDON-TEXIST" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/yusuf-daglioglu"><img src="https://avatars.githubusercontent.com/u/90555550?v=4" width="100px;" loading=lazy /><br /><sub><b>Yusuf Daglioglu</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=yusuf-daglioglu" title="Documentation">📖</a></td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://ycao.net/"><img src="https://avatars.githubusercontent.com/u/32544798?v=4" width="100px;" loading=lazy /><br /><sub><b>Yi Cao</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=yikerman" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/sdhlfqr"><img src="https://avatars.githubusercontent.com/u/155405590?v=4" width="100px;" loading=lazy /><br /><sub><b>Sayf Dhū al-Faqār</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=sdhlfqr" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/eylenburg"><img src="https://avatars.githubusercontent.com/u/84839316?v=4" width="100px;" loading=lazy /><br /><sub><b>eylenburg</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=eylenburg" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/PASSK3YS"><img src="https://avatars.githubusercontent.com/u/54213179?v=4" width="100px;" loading=lazy /><br /><sub><b>Kieran Colfer</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=PASSK3YS" title="Documentation">📖</a></td> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/SamsungGalaxyPlayer"><img src="https://avatars.githubusercontent.com/u/12520755?v=4" width="100px;" loading=lazy /><br /><sub><b>Justin Ehrenhofer</b></sub></a><br /><a href="https://github.com/privacyguides/privacyguides.org/commits?author=SamsungGalaxyPlayer" title="Documentation">📖</a> <a href="#business-SamsungGalaxyPlayer" title="Business development">💼</a> <a href="#fundingFinding-SamsungGalaxyPlayer" title="Funding Finding">🔍</a></td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|       <td align="center" valign="top" width="20%"><a rel="nofollow noopener noreferrer" href="https://github.com/bruch-alex"><img src="https://avatars.githubusercontent.com/u/173354246?v=4" width="100px;" loading=lazy /><br /><sub><b>Alex Bruch</b></sub></a><br /><a href="#translation-bruch-alex" title="Translation">🌍</a></td> | ||||
|     </tr> | ||||
|   </tbody> | ||||
|   <tfoot> | ||||
|     <tr> | ||||
|       <td align="center" size="13px" colspan="5"> | ||||
|         <img src="https://raw.githubusercontent.com/all-contributors/all-contributors-cli/1b8533af435da9854653492b1327a23a4dbd0a10/assets/logo-small.svg"> | ||||
|           <a href="https://all-contributors.js.org/docs/en/bot/usage">Add your contributions</a> | ||||
|         </img> | ||||
|       </td> | ||||
|     </tr> | ||||
|   </tfoot> | ||||
| </table> | ||||
|  | ||||
| <!-- markdownlint-restore --> | ||||
| <!-- prettier-ignore-end --> | ||||
|  | ||||
| <!-- ALL-CONTRIBUTORS-LIST:END --> | ||||
|  | ||||
| This project follows the [all-contributors](https://github.com/all-contributors/all-contributors) specification. Contributions of **any** kind welcome, including contributions to Privacy Guides outside of this repo, and contributions that aren't content related (like sharing ideas for Privacy Guides, promoting the project, answering questions on the forum, etc.). | ||||
|  | ||||
| CLI to generate this table: | ||||
|  | ||||
| ```bash | ||||
| npx --package all-contributors-cli -- npx all-contributors generate | ||||
| ``` | ||||
|  | ||||
| CLI to add a contributor: | ||||
|  | ||||
| ```bash | ||||
| npx --package all-contributors-cli -- npx all-contributors add <username> <contribution> | ||||
| ``` | ||||
|  | ||||
| See [this table](https://allcontributors.org/docs/en/emoji-key) for valid contribution reasons, comma-separated. Do **not** use the `content` code for contributors to the website, use `docs` instead (this way it will automatically link to their commits). Example: | ||||
|  | ||||
| ```bash | ||||
| npx --package all-contributors-cli -- npx all-contributors add jonaharagon docs,research,question | ||||
| ``` | ||||
|   | ||||
							
								
								
									
										63
									
								
								blog/.authors.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,63 @@ | ||||
| authors: | ||||
|   contributors: | ||||
|     type: Organization | ||||
|     name: Privacy Guides | ||||
|     description: Various Authors | ||||
|     avatar: https://github.com/privacyguides.png | ||||
|   danarel: | ||||
|     name: Dan Arel | ||||
|     description: Former Team Member | ||||
|     avatar: https://github.com/danarel.png | ||||
|   niek-de-wilde: | ||||
|     name: Niek de Wilde | ||||
|     description: Team Member | ||||
|     avatar: https://github.com/blacklight447.png | ||||
|     mastodon: | ||||
|       username: blacklight447 | ||||
|       instance: mastodon.social | ||||
|   dngray: | ||||
|     name: Daniel Gray | ||||
|     description: Team Member | ||||
|     avatar: https://github.com/dngray.png | ||||
|   freddy: | ||||
|     name: Freddy | ||||
|     description: Team Member | ||||
|     avatar: https://github.com/freddy-m.png | ||||
|     mastodon: | ||||
|       username: freddy | ||||
|       instance: social.lol | ||||
|     twitter: m00ws | ||||
|     bluesky: freddy.lol | ||||
|   jonah: | ||||
|     name: Jonah Aragon | ||||
|     description: Project Director | ||||
|     avatar: https://github.com/jonaharagon.png | ||||
|     mastodon: | ||||
|       username: jonah | ||||
|       instance: neat.computer | ||||
|     twitter: jonaharagon | ||||
|     bluesky: jonaharagon.com | ||||
|   kaitebay: | ||||
|     name: Kai Tebay | ||||
|     description: Former Team Member | ||||
|     avatar: https://github.com/kaitebay.png | ||||
|   matchboxbananasynergy: | ||||
|     name: mbananasynergy | ||||
|     description: Former Team Member | ||||
|     avatar: https://github.com/matchboxbananasynergy.png | ||||
|   mfwmyfacewhen: | ||||
|     name: mfwmyfacewhen | ||||
|     description: Former Team Member | ||||
|     avatar: https://github.com/ghost.png | ||||
|   natebartram: | ||||
|     name: Nate Bartram | ||||
|     description: Guest Contributor | ||||
|     avatar: https://gitlab.com/uploads/-/system/user/avatar/8993331/avatar.png | ||||
|   sam-howell: | ||||
|     name: Sam Howell | ||||
|     description: Guest Contributor | ||||
|     avatar: https://gitlab.com/uploads/-/system/user/avatar/5349522/avatar.png | ||||
|   fria: | ||||
|     name: fria | ||||
|     description: Team Member | ||||
|     avatar: https://github.com/friadev.png | ||||
							
								
								
									
										5
									
								
								blog/archive/2019.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,5 @@ | ||||
| # 2019 | ||||
|  | ||||
| !!! danger "Old Content" | ||||
|  | ||||
|     These posts are 5 years old. They may not accurately reflect the current opinion of our team. | ||||
							
								
								
									
										5
									
								
								blog/archive/2020.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,5 @@ | ||||
| # 2020 | ||||
|  | ||||
| !!! danger "Old Content" | ||||
|  | ||||
|     These posts are 4 years old. They may not accurately reflect the current opinion of our team. | ||||
							
								
								
									
										5
									
								
								blog/archive/2021.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,5 @@ | ||||
| # 2021 | ||||
|  | ||||
| !!! danger "Old Content" | ||||
|  | ||||
|     These posts are 3 years old. They may not accurately reflect the current opinion of our team. | ||||
							
								
								
									
										5
									
								
								blog/archive/2022.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,5 @@ | ||||
| # 2022 | ||||
|  | ||||
| !!! danger "Old Content" | ||||
|  | ||||
|     These posts are 2 years old. They may not accurately reflect the current opinion of our team. | ||||
							
								
								
									
										
											BIN
										
									
								
								blog/assets/images/choosing-the-right-messenger/cover.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 1011 KiB | 
							
								
								
									
										
											BIN
										
									
								
								blog/assets/images/data-erasure/shredos.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 3.9 KiB | 
							
								
								
									
										
											BIN
										
									
								
								blog/assets/images/delisting-startpage/cover.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 607 KiB | 
							
								
								
									
										
											BIN
										
									
								
								blog/assets/images/delisting-wire/cover.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 415 KiB | 
							
								
								
									
										
											BIN
										
									
								
								blog/assets/images/firefox-privacy/cover.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 955 KiB | 
| After Width: | Height: | Size: 3.0 MiB | 
							
								
								
									
										
											BIN
										
									
								
								blog/assets/images/merch-announcement/cover.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 488 KiB | 
							
								
								
									
										
											BIN
										
									
								
								blog/assets/images/metadata-removal/preview-ios.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 135 KiB | 
							
								
								
									
										
											BIN
										
									
								
								blog/assets/images/metadata-removal/preview-macos.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 590 KiB | 
							
								
								
									
										
											BIN
										
									
								
								blog/assets/images/metadata-removal/preview-windows.jpg
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 70 KiB | 
							
								
								
									
										
											BIN
										
									
								
								blog/assets/images/metadata-removal/shortcut-ios.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 114 KiB | 
							
								
								
									
										
											BIN
										
									
								
								blog/assets/images/metadata-removal/shortcut-macos.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 93 KiB | 
							
								
								
									
										
											BIN
										
									
								
								blog/assets/images/mozilla-disappoints-us-yet-again-2/cover.jpeg
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 96 KiB | 
| After Width: | Height: | Size: 532 KiB | 
| After Width: | Height: | Size: 258 KiB | 
| After Width: | Height: | Size: 181 KiB | 
| After Width: | Height: | Size: 162 KiB | 
| After Width: | Height: | Size: 304 KiB | 
| After Width: | Height: | Size: 183 KiB | 
| After Width: | Height: | Size: 532 KiB | 
| After Width: | Height: | Size: 256 KiB | 
| After Width: | Height: | Size: 240 KiB | 
							
								
								
									
										
											BIN
										
									
								
								blog/assets/images/proton-wallet-review/1.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 437 KiB | 
							
								
								
									
										
											BIN
										
									
								
								blog/assets/images/proton-wallet-review/2.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 194 KiB | 
							
								
								
									
										
											BIN
										
									
								
								blog/assets/images/proton-wallet-review/3.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 555 KiB | 
							
								
								
									
										
											BIN
										
									
								
								blog/assets/images/proton-wallet-review/4.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 370 KiB | 
							
								
								
									
										
											BIN
										
									
								
								blog/assets/images/pwa-vs-iwa/iwa-diagram.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 94 KiB | 
							
								
								
									
										
											BIN
										
									
								
								blog/assets/images/relisting-startpage/cover.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 49 KiB | 
							
								
								
									
										
											BIN
										
									
								
								blog/assets/images/restrict-act/cover.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 2.4 MiB | 
							
								
								
									
										
											BIN
										
									
								
								blog/assets/images/security-privacy-anonymity/cover.jpeg
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 144 KiB | 
| After Width: | Height: | Size: 785 KiB | 
| After Width: | Height: | Size: 202 KiB | 
							
								
								
									
										
											BIN
										
									
								
								blog/assets/images/threads-launch-twitter/cover.jpg
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 1.2 MiB | 
							
								
								
									
										
											BIN
										
									
								
								blog/assets/images/twitter-elon-takeover/cover.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 557 KiB | 
| After Width: | Height: | Size: 30 KiB | 
							
								
								
									
										
											BIN
										
									
								
								blog/assets/images/why-i-run-a-tor-relay/cover.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 369 KiB | 
							
								
								
									
										1
									
								
								blog/author/dngray.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1 @@ | ||||
| # Daniel Gray | ||||
							
								
								
									
										7
									
								
								blog/author/freddy.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,7 @@ | ||||
| # Freddy | ||||
|  | ||||
| { align=right } | ||||
|  | ||||
| [**Freddy**](https://freddy.lol) is a founding member of Privacy Guides and the editor of its blog. He writes in American English reluctantly. | ||||
|  | ||||
| [:simple-mastodon: @freddy@social.lol](https://social.lol/@freddy "@freddy@social.lol"){ .md-button rel=me } | ||||
							
								
								
									
										37
									
								
								blog/author/jonah.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,37 @@ | ||||
| --- | ||||
| description: Jonah Aragon is the Project Director and staff writer at Privacy Guides. His role includes researching and writing for this website, system administration, creating Privacy Guides Online Learning course content, reviewing the products recommended here, and most other day-to-day tasks. | ||||
| schema: | ||||
|   - | ||||
|     "@context": https://schema.org | ||||
|     "@type": ProfilePage | ||||
|     dateCreated: "2019-10-31T00:00:00Z" | ||||
|     dateModified: "2024-09-09T00:00:00Z" | ||||
|     mainEntity: | ||||
|       - | ||||
|         "@context": https://schema.org | ||||
|         "@type": Person | ||||
|         name: Jonah Aragon | ||||
|         jobTitle: Project Director | ||||
|         description: Jonah Aragon is the Project Director and staff writer at Privacy Guides. | ||||
|         url: https://www.privacyguides.org/articles/author/jonah/ | ||||
|         image: https://www.privacyguides.org/articles/assets/external/github.com/jonaharagon.png.jpg | ||||
|         sameAs: | ||||
|           - https://www.jonaharagon.com | ||||
|           - https://discuss.privacyguides.net/u/jonah | ||||
|           - https://shop.jonaharagon.com | ||||
|           - https://jonaharagon.me | ||||
|           - https://mastodon.neat.computer/@jonah | ||||
|           - https://www.youtube.com/@jonaharagon | ||||
|           - https://www.wikidata.org/wiki/Q117304062 | ||||
| --- | ||||
|  | ||||
| # Jonah Aragon | ||||
|  | ||||
| { align=right } | ||||
|  | ||||
| [**Jonah Aragon**](https://www.jonaharagon.com) is the Project Director and staff writer at *Privacy Guides*. His role includes researching and writing for this website, system administration, creating Privacy Guides Online Learning course content, reviewing the products recommended here, and most other day-to-day tasks. | ||||
|  | ||||
| He is also known for his work on the Techlore YouTube channel, including the Techlore Talks podcast he co-hosts. | ||||
|  | ||||
| [:simple-mastodon: @jonah@neat.computer](https://mastodon.neat.computer/@jonah "@jonah@neat.computer"){ .md-button rel=me } | ||||
| [:simple-bluesky: @jonaharagon.com](https://bsky.app/profile/jonaharagon.com "@jonaharagon.com"){ .md-button rel=me } | ||||
							
								
								
									
										7
									
								
								blog/author/niek-de-wilde.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,7 @@ | ||||
| # Niek de Wilde | ||||
|  | ||||
| { align=right } | ||||
|  | ||||
| **Niek** is a founding team member of Privacy Guides and part of the [executive committee](https://www.privacyguides.org/en/about/#executive-committee). His day-to-day concerns for Privacy Guides entail both research and outreach. | ||||
|  | ||||
| [:simple-mastodon: @blacklight447@mastodon.social](https://mastodon.social/@blacklight447 "@blacklight447@mastodon.social"){ .md-button rel=me } | ||||
							
								
								
									
										7
									
								
								blog/category/announcements.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,7 @@ | ||||
| --- | ||||
| description: The latest announcements and updates from the Privacy Guides team. | ||||
| --- | ||||
|  | ||||
| # Announcements | ||||
|  | ||||
| Follow this page for the latest updates & announcements from the Privacy Guides team, and join the [announcements category](https://discuss.privacyguides.net/c/announcements/5) on our forum to discuss anything you read here! | ||||
							
								
								
									
										7
									
								
								blog/category/news.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,7 @@ | ||||
| --- | ||||
| description: Privacy Guides News presents the latest tech news about the world's best (and occasionally worst) software, hardware, and services in the privacy world. | ||||
| --- | ||||
|  | ||||
| # News | ||||
|  | ||||
| The latest tech news about the world's best (and occasionally worst) software, hardware, and services in the privacy world. *Privacy Guides News* has you covered for any important information you might need on your privacy journey. | ||||
							
								
								
									
										7
									
								
								blog/category/reviews.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,7 @@ | ||||
| --- | ||||
| description: Read the latest privacy product reviews and stories from Privacy Guides contributing writers. | ||||
| --- | ||||
|  | ||||
| # Reviews | ||||
|  | ||||
| Looking for alternatives to privacy-invasive apps you use everyday? Do you just want to know all the details behind your favorite privacy tools? *Privacy Guides Reviews* is the place to find all that and more. This is your one stop to find the latest advice and recommendations on things we use every day directly from Privacy Guides contributors. | ||||
							
								
								
									
										107
									
								
								blog/editorial.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,107 @@ | ||||
| --- | ||||
| title: Editorial Policy | ||||
| --- | ||||
|  | ||||
| This page provides transparent information about Privacy Guides, its editorial process, and how Privacy Guides creates trustworthy news, articles, and reviews. | ||||
|  | ||||
| Moreover, it is a part of Privacy Guides' commitment to [**The Trust Project**](https://thetrustproject.org/), "an international consortium of news organizations implementing transparency standards and working with technology platforms to affirm and amplify journalism’s commitment to transparency, accuracy, inclusion and fairness so that the public can make informed news choices." Privacy Guides is not currently a news partner of the program, but wholeheartedly supports its mission and values. | ||||
|  | ||||
| ## Coverage Priorities | ||||
|  | ||||
| First and foremost, Privacy Guides is committed to publishing content related to the personal privacy and cybersecurity industry and communities. We firmly believe that privacy is a human right, which should not be intruded upon by any corporation, government, or other entity. | ||||
|  | ||||
| To further our beliefs, Privacy Guides strives to create coverage that promotes the ideals of personal privacy and security in online spaces, encourages companies to engage in privacy-friendly behavior, and holds privacy and security invasive entities accountable for their actions. | ||||
|  | ||||
| ## Our Philosophy | ||||
|  | ||||
| Privacy Guides strongly believes in independent information published by independent people with varying points of view. As an organization, we are firm proponents of freedom of speech, expression, and the press. Privacy Guides contributors are free to share their own opinions, even when they are controversial. Every opinion article is clearly labeled as such at the beginning of the news content. | ||||
|  | ||||
| ## Ethics Policy | ||||
|  | ||||
| Privacy Guides' ethical code is based in our willingness to be accurate, fair, and complete, and for all of our writers to act with honesty, transparency, and independence. | ||||
|  | ||||
| ### Truth and Accuracy | ||||
|  | ||||
| Privacy Guides contributors are expected to be as accurate as possible. Getting facts from reliable sources is the defining principle of journalism. Privacy Guides always strives to provide all the relevant facts available, ensure those facts have been verified, and generally hold ourselves to the highest standards of accuracy and truth. When we are unable to corroborate certain information, Privacy Guides always makes that clear to readers. | ||||
|  | ||||
| ### Independence | ||||
|  | ||||
| Privacy Guides contributors must always be independent voices in the privacy community. Privacy Guides does not act on behalf of special interests, whether corporate, political, or cultural, and whether formally or informally. Independent fact-checking is always involved in the publication process. | ||||
|  | ||||
| ### Fairness and Impartiality | ||||
|  | ||||
| Many stories have at least two sides. While we are not obligated to present every viewpoint in every article we publish, our stories are balanced and add context. Our impertial reporting is a significant part of why our community has trust and confidence in our work. | ||||
|  | ||||
| ### Humanity | ||||
|  | ||||
| Privacy Guides contributors do no harm. We are aware of the impact of our words on the lives of others. Private persons have privacy rights that must be balanced against the public interest in reporting information about them. Our pursuit of the news is not a license for arrogance, and we will always treat the subject of any story with respect. | ||||
|  | ||||
| ### Accountability | ||||
|  | ||||
| As professional and responsible journalists, we will always hold ourselves accountable for our work. Corrections are published when errors are discovered, and we always listen to the concerns of our audience. | ||||
|  | ||||
| ## Corrections Policy | ||||
|  | ||||
| Privacy Guides believes in transparency and honesty. Therefore, we will correct mistakes promptly and ensure our readers are notified. In the online world of journalism, completeness and freshness of content are huge values, and we believe accuracy is equally essential. We will ensure expediency when making corrections as needed. | ||||
|  | ||||
| When an error is detected in an article, Privacy Guides will immediately work to find the correct information, clearly display the correction within the affected article, and include the following: | ||||
|  | ||||
| - The correct information. | ||||
| - What was originally published that was incorrect. | ||||
| - The severity of the error. | ||||
| - The date when the change took place. | ||||
|  | ||||
| When errors cannot be amended within the body of an article's content, corrections are displayed in the last paragraph of the content. Rather than remove completely the content containing a mistake, we provide clarification and admittance of our mistakes to preserve transparency. | ||||
|  | ||||
| ## Verification & Fact-Checking | ||||
|  | ||||
| Privacy Guides prides itself on the validity of its content, and therefore does whatever it can to ensure that the information presented by its contributors is accurate. As a well-known global publication, Privacy Guides understands the importance of approaching claims with skepticism, thinking critically, and upholding accuracy in whatever way possible. | ||||
|  | ||||
| Privacy Guides encourages its writers to keep the following considerations in mind before publishing content: | ||||
|  | ||||
| - Always credit, acknowledge, and verify the source(s) of your information. | ||||
| - Consider whether you know enough about the information to qualify as a trustable source yourself. | ||||
| - Think critically when addressing claims. | ||||
| - Never make assumptions. | ||||
|  | ||||
| We trust the integrity of our contributors and the accuracy of content published on this website. In the case that a mistake is made, we understand the importance of admitting to them and working diligently to provide the correct information. We always encourage our readers, sources, and other contributors to provide us with feedback on any of our content. | ||||
|  | ||||
| ## Unnamed Sources Policy | ||||
|  | ||||
| Privacy Guides will only used unnamed sources in our news reporting if: | ||||
|  | ||||
| 1. The material is informative, not opinion or speculation. | ||||
| 2. The material is vital to the news report. | ||||
| 3. The source is reliable, and in a position to have accurate information. | ||||
| 4. The information provided is not available except under conditions of anonymity imposed by the source. | ||||
|  | ||||
| Privacy Guides will always identify sources whenever possible. Our readership is entitled to as much information as possible in order to judge the reliability of our sources themselves. | ||||
|  | ||||
| :   Privacy Guides' credibility is our most important asset. If our readers don't have faith that the stories they are reading here are accurate and fair, or if they suspect content within the stories we publish is fabricated, then we would lose that credibility. For our contributors to protect their own credibility, they must use every available avenue to confirm and attribute information before relying on unnamed sources. If the only way to publish a story is to use unnamed sources, our contributors owe it to our readership to identify the sources as clearly as possible without exposing the identity of the individual granted anonymity. | ||||
|  | ||||
| Our contributors should always question the motives behind a source requesting anonymity. | ||||
|  | ||||
| :   Always keep your promises, but clarify conditions attached to any promise made in exchange for information beforehand. You must not take information from an anonymous support without the approval of our editorial team. We only use unnamed sources to tell important stories that would otherwise go unreported. | ||||
|  | ||||
| The decision to use an unnamed source is not a decision made solely by the writer. To use an unnamed source, a contributor must have the written consent of a member of our editorial team: [Daniel](author/dngray.md), [Freddy](author/freddy.md), [Jonah](author/jonah.md), or [Niek](author/niek-de-wilde.md). | ||||
|  | ||||
| Our editorial team will grant consent to the use of unnamed sources if the source is considered to be accurate and reliable, and if there is substantial justification for using the source's information without attribution. Privacy Guides should never be in the position of having to verify any factors within this policy after a story has been published. | ||||
|  | ||||
| ## Actionable Feedback | ||||
|  | ||||
| Privacy Guides is committed to engaging with our readers and taking action based on their suggestions, complaints, and other feedback. | ||||
|  | ||||
| Readers may help us develop an individual story or line of coverage, answer questions that a story may raise, identify related or under-covered issues, and teach us about new and diverse sources, experts, and perspectives. We believe that news organizations have a responsibility to engage with the public on the values, issues, and ideas of the times, and that news organizations have much to gain in return. In fact, actionable feedback may: | ||||
|  | ||||
| - Further develop an individual story or line of coverage. | ||||
| - Help answer questions that a story may raise. | ||||
| - Help identify related questions or issues that the audience, including demographic segments of that audience, is discussing or are concerned about. | ||||
| - Yield new and diverse sources and experts. | ||||
|  | ||||
| **We strongly encourage our readers to participate in our community forum: <https://discuss.privacyguides.net/>** | ||||
|  | ||||
| Our staff contributors are also [listed](https://www.privacyguides.org/en/about/) alongside verified email links and other contact information, where you can ask them questions or report a complaint. Each article within our news section also clearly lists the author's byline, including contact and social media information when available. | ||||
|  | ||||
| When necessary, we will make updates to our articles based on our readership's comments and feedback. | ||||
|  | ||||
| We are proud of keeping this openness a top priority, in line with the nature of our community. | ||||
							
								
								
									
										11
									
								
								blog/index.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,11 @@ | ||||
| --- | ||||
| description: Privacy-related news stories, product reviews, opinion pieces, and other important articles from Privacy Guides contributors. | ||||
| hide: | ||||
|   - footer | ||||
| --- | ||||
|  | ||||
| # Latest Articles | ||||
|  | ||||
| This is our home for privacy-related news stories, product reviews, opinion pieces, and other important articles. | ||||
|  | ||||
| Unlike the rest of our website, these articles don't represent a consensus viewpoint of our community. Instead, they present the opinions of trusted authors within our community as-is. You may even find multiple articles on the same topic with competing viewpoints, intended to further [privacy discussion](https://discuss.privacyguides.net/). | ||||
							
								
								
									
										3
									
								
								blog/posts/.meta.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,3 @@ | ||||
| comments: true | ||||
| social: | ||||
|   cards_layout: blog | ||||
							
								
								
									
										48
									
								
								blog/posts/bad-faith-arguments.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,48 @@ | ||||
| --- | ||||
| date: | ||||
|     created: 2024-09-09 | ||||
| categories: | ||||
|     - Announcements | ||||
| authors: | ||||
|     - jonah | ||||
| tags: | ||||
|     - Privacy Guides | ||||
| license: BY-SA | ||||
| --- | ||||
| # Bad-Faith Arguments in the Privacy Community | ||||
|  | ||||
| The Privacy Guides community is one of the best privacy-related communities on the internet, and I think we have generally done a good job at promoting a positive and respectful environment where people can learn and grow. | ||||
|  | ||||
| Unfortunately, as a public forum we are not immune to the small minority of individuals who feel empowered to spread anger, hostility, and divisiveness by their anonymity and general lack of consequences on the internet.<!-- more --> | ||||
|  | ||||
| From now on, we are going to be strict about requiring all posts in our communities to be made in good faith. | ||||
|  | ||||
| We will consider the following questions when reviewing posts: | ||||
|  | ||||
| 1. Is the poster presenting their criticism as informed or factual, when it's actually a matter of personal opinion, or worse, misinformation or false? | ||||
| 2. Has the poster failed to provide reasoning for their criticism, and demonstrated an unwillingness to learn or discuss the topic? | ||||
| 3. Is the poster writing something as if it is true and informed, when they're actually just speculating? | ||||
| 4. Is the poster simply spreading negativity instead of actually trying to improve something? | ||||
| 5. Is the poster engaging in ad hominem attacks against us or our community? | ||||
|  | ||||
| If these answer to any of these questions is yes, the post will be removed and the poster will be asked to revise their statement. We will suspend posters who repeatedly engage in bad faith arguments. | ||||
|  | ||||
| For almost everyone here, you won't see any negative impacts of this new policy. It is simply designed to allow us to remove the small number of people who occasionally join to spread unproductive negativity in the privacy space, at the expense of legitimate projects making the world a better place. Hopefully you will notice improvements in discussion quality overall. | ||||
|  | ||||
| --- | ||||
|  | ||||
| To give an example, there are two specific behaviors we want to discourage with this new policy. | ||||
|  | ||||
| 1. The constant use of words like "shilling," "fanboys," etc. to describe people who have a difference in opinion to your own is not acceptable. | ||||
|  | ||||
|     To "[shill](https://en.wikipedia.org/wiki/Shill)" something is to promote something you have an employer relationship or some other actual conflict of interest with. To accuse someone in our community of being a planted shill without any evidence, simply because they like something that you dislike, is both a serious accusation and a bad-faith argument. | ||||
|  | ||||
|     Even the use of terms like these informally to describe people who like a certain product more than others is disrespectful, and sows uncertainty and distrust within our community, so it will no longer be tolerated. | ||||
|  | ||||
| 2. A very small portion of GrapheneOS community members continually attempt to derail any conversations mentioning GrapheneOS with irrelevant details and confrontational attitudes. | ||||
|  | ||||
|     This is not a reflection on the GrapheneOS project itself, but unfortunately this has become a repeated situation with certain community members of this specific project more than anyone else, so we have to call it out. | ||||
|  | ||||
|     Making unfounded accusations against Privacy Guides community members of harassment towards GrapheneOS simply because they presented their criticism of the project is not a good faith argument. Similarly, presenting unverified statements from the GrapheneOS community as factual has led to misinformation being spread in the past. It is critical to always differentiate between opinions/beliefs and factual information. | ||||
|  | ||||
|     **Privacy Guides community spaces are not GrapheneOS discussion forums, and the drama from their community is not automatically on-topic in ours.** Please do not make new topics in our forum that simply link to drama posts from the GrapheneOS community. A good rule of thumb is that unless a post from GrapheneOS is specifically talking about GrapheneOS-specific, privacy-related functionality and not about other projects/software/etc., it is probably off-topic here. | ||||
							
								
								
									
										117
									
								
								blog/posts/choosing-the-right-messenger.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,117 @@ | ||||
| --- | ||||
| date: | ||||
|     created: 2019-11-27 | ||||
| categories: | ||||
|     - Opinion | ||||
| authors: | ||||
|     - danarel | ||||
| links: | ||||
|     - Real Time Communication: https://www.privacyguides.org/real-time-communication/ | ||||
|     - Types of Communication Networks: https://www.privacyguides.org/real-time-communication/communication-network-types/ | ||||
| tags: | ||||
|     - Instant Messengers | ||||
| license: BY-SA | ||||
| description: Choosing an instant messenger is a challenge. How can you be sure you’re using the most secure, privacy respecting platform? | ||||
| schema_type: AnalysisNewsArticle | ||||
| --- | ||||
| # Choosing the Right Messenger | ||||
|  | ||||
|  | ||||
|  | ||||
| One of the most common questions users have when it comes to privacy is about messaging services. It seems almost all of them mention some level of privacy or encryption to entice the user to sign up for their service, but how can you be sure you’re using the most secure, privacy respecting platform?<!-- more --> | ||||
|  | ||||
| The answer actually lies in one’s [threat model](https://www.privacyguides.org/basics/threat-modeling/), which is often an ignored step in choosing all privacy related apps and services, meaning a lot of users limit their internet and communication experience because they believe they need Edward Snowden level privacy settings. | ||||
|  | ||||
| The truth is, each user needs to decide what their privacy goals are. Is your goal to stop corporations from tracking you, targeting you, and profiting from your data? Or, are you are trying to hide communications from the government or law enforcement, which is common for journalists and activists who want to protect their sources or communications from government eyes? | ||||
|  | ||||
| Once you understand your goals you can start to look at messengers and their upsides and downsides, and it’s important to remember, there is no perfect solution. Each service, no matter how secure can be compromised, because at the end of the day, you’re dealing with other humans who can screenshot, copy, or forward your messages to parties you did not intend to see them. So, it’s also important to know who you are messaging, verifying their keys, and ensuring that you place the utmost trust in them with the content you are sending. | ||||
|  | ||||
| If your goal is to simply avoid corporate tracking and the harvesting of your data from your communications, you can eliminate apps such as Facebook Messenger and WhatsApp, both services owned by Facebook and while offering encrypted messaging (optional in Messenger), Facebook [reads your non-encrypted messages](https://web.archive.org/web/20210729190737/https://www.digitaltrends.com/social-media/facebook-reads-messenger-messages/), and WhatsApp has [fallen victim](https://web.archive.org/web/20210729190737/https://www.forbes.com/sites/zakdoffman/2019/05/14/whatsapps-cybersecurity-breach-phones-hit-with-israeli-spyware-over-voice-calls/#734cec155549) to security breaches. | ||||
|  | ||||
| For this type of user, your options are much more wide as you may be more willing to share your email address or phone number at signup and can be less concerned with metadata (we will get to that shortly), and you want to look for a messenger that simply isn’t scanning your content or behavior to sell it. | ||||
|  | ||||
| If your goal is to evade more massive state-sponsored surveillance programs, the aforementioned apps are out of the question, but so are many others. | ||||
|  | ||||
| This is because when it comes to these apps, and other like it, you don’t own the encryption keys, the service does, so they are able to decrypt your messages, for their own use, or for the use of government officials who request it. This is something important you’ll want to remember as you choose the messenger that is right for you. | ||||
|  | ||||
| Even Apple’s iMessage, which is encrypted, while more secure than Facebook’s offerings, still control the keys and can access your messages if necessary. Apple does also collect data based on your behavior, so while using iMessage isn’t the same as handing your data over to Facebook, you’re still messaging with a variety of privacy vulnerabilities. On Android, you’re using SMS messages which are even less secure and can be [easily hijacked](https://web.archive.org/web/20210729190737/https://www.theverge.com/2017/9/18/16328172/sms-two-factor-authentication-hack-password-bitcoin) by someone with just enough know-how. | ||||
|  | ||||
| ## Metadata | ||||
|  | ||||
| One important aspect of messaging apps you need to be sure of is what kind of [metadata](https://ssd.eff.org/en/glossary/metadata) it exposes, what is encrypted and what isn’t. | ||||
|  | ||||
| Wire, a popular encrypted messenger app has always been criticized for its decision not to encrypt user metadata, such as the date and time of registration, IP geographical coordinates, and the date and time of creation, creator, name, and list of participants in a conversation. | ||||
|  | ||||
| Metadata can be used to place you in a certain location, speaking to a certain person and can be used against you by law enforcement, even if they have no idea and no access to what the conversation was about. | ||||
|  | ||||
| Apps such as Signal, or Wickr encrypt metadata, making the conversations between two or more parties more secure and harder to track individual users with. | ||||
|  | ||||
| When it comes to avoiding corporate data mining, your metadata won’t be as useful, especially if you’re using a service that is not profiting from your data to begin with. For those avoiding state-sponsored surveillance, [metadata can be a killer](https://web.archive.org/web/20210729190737/https://theintercept.com/2019/08/04/whistleblowers-surveillance-fbi-trump/). | ||||
|  | ||||
| ## Encryption | ||||
|  | ||||
| This article will not get into the complexities of the best kinds of end-to-end encryption (E2EE), but ensuring your messenger has it, that must be discussed. | ||||
|  | ||||
| The popular messaging app Telegram has come under fire the most for this. Telegram says on their homepage that, “Telegram messages are heavily encrypted and can self-destruct.” Yet, this statement is only partially true. Yes, you can set your messages to self-destruct, a great privacy feature for some, and yes, they do offer encryption, but what they don’t tell users is that encryption isn’t turned on by default. | ||||
|  | ||||
| In an [interview](https://web.archive.org/web/20210729190737/https://gizmodo.com/why-you-should-stop-using-telegram-right-now-1782557415) with Gizmodo, Christopher Soghoian, Principal Technologist and Senior Policy Analyst at the American Civil Liberties Union said that, "There are many Telegram users who think they are communicating in an [end-to-end] encrypted way, when they’re not because they don’t realize that they have to turn on an additional setting,” he continued to say that while he’s happy they offer the encryption, it’s not useful if it’s turned off. | ||||
|  | ||||
| Apps such as Signal, Keybase, and Wickr offer E2EE by default. Less popular but quickly growing apps such as Element, offer E2EE but like Telegram, have not made it a default setting, though the Matrix.org team has [said](https://web.archive.org/web/20210729190737/https://github.com/vector-im/element-web/issues/6779) that default encryption is on their road map. | ||||
|  | ||||
| Ensuring your conversations and metadata are E2EE is one of the best practices you can have when choosing a messenger. | ||||
|  | ||||
| ## Registration Process | ||||
|  | ||||
| When it comes to your goals and threat model, you will need to decide how much, if any, information you’re willing to give this company on signup. Do they require a phone number and or SIM card? Do they require an email address, or do they allow completely anonymous signups, and how anonymous is anonymous? Are they storing that info (remember the metadata) unencrypted? | ||||
|  | ||||
| Giving up your phone number or email won’t be a big deal for many, as any good privacy policy will state they won’t use it for any purpose other than those you’ve granted permission for. Yet, for those avoiding state-sponsored surveillance, you may have a regularly changing number, no number, or would rather not risk giving that information up. Same goes for email. | ||||
|  | ||||
| So, you will want to find a service that fits this need. While Signal is currently testing signup without a phone number, currently you’re unable to do so. Element, Wickr, many XMPP services, don’t require anything but choosing a username. | ||||
|  | ||||
| ## Source Code | ||||
|  | ||||
| Open source may be the most used phrase in all of privacy and security, and for good reason. It’s really helpful to be able to review the source code of the product you’re trusting. Experts can look for backdoors, leaks, and other bugs. Organizations that opt to open source their code are showing good faith effort to increase trust between them and the user. | ||||
|  | ||||
| Yet, open source can also limit your options, again, depending on your threat model and goals. Signal, Wire, and Keybase all offer open source repositories of their applications, and sometimes even the server software itself. | ||||
|  | ||||
| Open source also doesn’t mean secure. This is often misunderstood, and people hear open source and assume it must be good. Look at the apps code you want to use, you don’t need to be able to check it, but are others? An open source app that no one follows, or contributes to is no more or less secure than a closed source app. | ||||
|  | ||||
| Wickr, Threema, and others are closed source. They don’t offer the ability to check the source, but that doesn’t immediately rule them out either. When the Electronic Frontier Foundation (EFF) had a comparison chart for messenger apps, it gave Wickr 5-stars. This doesn’t mean it’s perfect for someone like Snowden, but for those avoiding Facebook and Google, it could be a usable option. | ||||
|  | ||||
| It’s also important to remember there’s no way to check that someone is always using the source code in their repository in the app or server you’re downloading from the Apple Store or Google Play. When it comes to this, reputation becomes a key player in your decision, as does trust, which we will get to next. | ||||
|  | ||||
| If you’re unsure what to do here, it’s always a safe bet to stick with open source that has a large contributor base and strong reputation. It’s always best to use open source options when they are available and only recommend closed source when there isn’t a usable open source option. This is generally a good way to pick a messenger app as well. | ||||
|  | ||||
| ## Ownership & Trust | ||||
|  | ||||
| An often overlooked, but increasingly important part of choosing a secure messenger is, who owns the company that’s providing your service? What would the gain or lose from selling your data and who does the company answer to? | ||||
|  | ||||
| Wire [recently lost](https://web.archive.org/web/20210729190737/https://blog.privacytools.io/delisting-wire/) a great deal of trust and standing in the privacy world because they quietly sold their company and moved it to the US. They also changed parts of their privacy policy making it harder for users to tell when Wire would share customer data. They did all of this while never updating their current users of such changes, either to the change of the privacy policy, or the move to the US. | ||||
|  | ||||
| Wire also took in more than $8 million in venture capital funding. So now, users wanted to know more about who owned their data and what jurisdictional rights were changing with the move from Europe to the United States? | ||||
|  | ||||
| These are questions we must ask of all services. Wire now has investors to answer to who will want a return on their millions of dollars. | ||||
|  | ||||
| Signal on the other hand is a [non-profit](https://signal.org/blog/signal-foundation/) which does not rely on investors and instead relies on donations, sponsorships, and grants. Because of their non-profit status in the US, they must also be highly transparent about not only where the money comes from, but how they spend it. So, users can see where this money goes, and who it’s going to. | ||||
|  | ||||
| Matrix.org (the service Element uses) runs a similar business model as Signal, located in the UK instead of the US, they reply on donations, partnerships, and grants. Matrix.org is heavily supported by New Vector, a venture capital backed company, however, Matrix.org as a non-profit is transparent about its spending, income, and influences. | ||||
|  | ||||
| Not all services are non-profit, and that should not rule them out immediately. You can also follow their funding goals. Wire lost credibility because instead of simply relying on user signups, they wanted to be the next Skype for Business and wanted to build a larger enough user base to get the attention of investors. Meanwhile apps such as Wickr, while for-profit, is transparent about taking limited investors to become sustainable on subscriptions. | ||||
|  | ||||
| This can take some time, because it’s important to know who the investors are, and what the organizational goals are. Will they eventually need to resort to data harvesting to sustain itself, if they do, and you decide to leave the platform, will you leave behind data you don’t want them to get their hands on? | ||||
|  | ||||
| ## Making Your Choice | ||||
|  | ||||
| Now it’s time to choose a messenger and no one can do that for you. Popularity will need to play a role here, there’s no point in joining the new up and coming messenger service if you don’t have a single contact using it as well. One reason Telegram has been so popular is they have managed to convince more than 100 million people to sign up. If you sign in today, you’ll likely see a group of your friends in there. Signal isn’t as far behind, and others are catching up. | ||||
|  | ||||
| You’ll need to decide who you trust, and who your other contacts trust, and then compare all of that with your goals and your threat model. How much information are you willing to give on signup, does metadata matter to your threat model, and is the service you’re choosing likely to sell itself to the highest bidder once enough people sign up? | ||||
|  | ||||
| The important thing to remember is there is no one size fits all for messengers, and that each user must decide what is best for them. If someone is an avid WhatsApp or Facebook Messenger user, even Telegram is a step in the right direction. Yet, if that user is concerned with more than just giving data over to Facebook, they may need to look at more secure options. | ||||
|  | ||||
| Ensure you keep your messenger apps up to date. You don’t want to discover you’ve been compromised because a bug found in version 1 was fixed in version 2 but you didn’t bother upgrading your apps. | ||||
|  | ||||
| One last piece of advice is that users need to be diligent and never become complacent in their decision. You must be willing to change services if the goals and values of your messenger of choice change in a way that no longer match yours. Look for news of sales, mergers, or acquisitions that could compromise the organization. | ||||
|  | ||||
| --- | ||||
|  | ||||
| *Dan Arel is a journalist, author, and privacy advocate. This article was originally published to [Hacker Noon](https://hackernoon.com/choosing-the-right-messenger-mm3x2z47) on November 27th, 2019.* | ||||
							
								
								
									
										45
									
								
								blog/posts/delisting-startpage.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,45 @@ | ||||
| --- | ||||
| date: | ||||
|     created: 2019-11-12 | ||||
| categories: | ||||
|     - Announcements | ||||
| authors: | ||||
|     - niek-de-wilde | ||||
| links: | ||||
|     - posts/relisting-startpage.md | ||||
|     - Search Engines: https://www.privacyguides.org/en/search-engines/ | ||||
| tags: | ||||
|     - Search Engines | ||||
| description: Startpage has been removed from Privacy Guides' recommendations following their acquisition by System1. | ||||
| schema_type: NewsArticle | ||||
| --- | ||||
| # Delisting Startpage From Privacy Guides | ||||
|  | ||||
|  | ||||
|  | ||||
| Dear *Privacy Guides* Community, | ||||
|  | ||||
| On the 15th of October, it was [brought to our attention](https://web.archive.org/web/20201127034309/https://www.reddit.com/r/privacy/comments/di5rn3/startpage_is_now_owned_by_an_advertising_company/) that Startpage.com was reportedly (partially?) taken over by a company called the Privacy One Group, which is in turn owned by a company called System1. We found this quite remarkable as the two companies seem to have conflicting business models.<!-- more --> Startpage has been known for basing their advertisements on what their users enter in their search bar. System1 on the other hand, is a pay-per-click advertising company that "[has developed a pre-targeting platform that identifies and unlocks  consumer intent across channels including social, native, email, search,  market research and lead generation rather than relying solely on what  consumers enter into search boxes.](https://web.archive.org/web/20201127034309/https://www.bizjournals.com/losangeles/news/2017/09/20/system1-raises-270-million-for-consumer-intent.html)" | ||||
|  | ||||
| We reached out to System1 CEO [Ian Weingarten](https://web.archive.org/web/20201127034309/https://finance.yahoo.com/news/system1-appoints-ian-weingarten-ceo-185700741.html) for an explanation. We received a very general response that did not address key questions. | ||||
|  | ||||
| Seemingly prompted by our ongoing concerns, Startpage released a public letter addressed to us from their CEO, and hosted a [Q&A](https://web.archive.org/web/20201127034309/https://www.reddit.com/r/StartpageSearch/comments/djshn3/hello_reddit_startpage_mod_team/) on their Subreddit to try and explain the situation. While some of our questions were answered, we noted that the company seemed to be evasive, essentially restating information from a previously published [blog post](https://web.archive.org/web/20201127034309/https://www.startpage.com/blog/company-updates/startpage-and-privacy-one-group/) or posting the same response to different questions. People had to really dig to get answers and puzzle all information together, instead of getting a clearly explained and comprehensive answer from the start. Requests for clarification to some important questions went ignored. | ||||
|  | ||||
| Because of the conflicting business model and the unusual way the company reacted, claiming to be fully transparent but being evasive at the same time, we have no choice but to de-list Startpage from our recommendations until it is fully transparent about its new ownership and data processing. Remaining questions include: | ||||
|  | ||||
| - The % of Startpage and Surfboard Holding B.V. (the Startpage holding company) System1 acquired in December 2018. | ||||
| - The current % ownership by System1 at the time of the audit (and any other major owners). | ||||
| - Information about Privacy One Group Ltd. Where is it registered and in what city, state and country does it operate? (We have not been able to verify registration information.) | ||||
| - A diagram of data flows, including flows to outside organizations, like System1, Privacy One etc. | ||||
|  | ||||
| This de-listing does not necessarily mean Startpage is violating its privacy policy. We have no evidence of that. But because there are still so many unanswered questions, we can no longer recommend the service with good confidence. If Startpage aims to be re-considered, they will have to answer the questions above, preferably along with an explanation of why it took them so long to get proper answers out to the public. | ||||
|  | ||||
| Sincerely, | ||||
| Blacklight447 | ||||
| *Privacy Guides* | ||||
|  | ||||
| --- | ||||
|  | ||||
| **2020-05-03:** Startpage has answered all of our questions for them and has clarified their policies. We have decided to recommend their service again, and you can read our latest [announcement](relisting-startpage.md) for more details. | ||||
|  | ||||
| **2023-10-23:** This post has been edited to reflect the team's move from [PrivacyTools](https://www.privacyguides.org/en/about/privacytools/) to Privacy Guides. | ||||
							
								
								
									
										42
									
								
								blog/posts/delisting-wire.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,42 @@ | ||||
| --- | ||||
| date: | ||||
|     created: 2019-11-19 | ||||
| categories: | ||||
|     - Announcements | ||||
| authors: | ||||
|     - danarel | ||||
| links: | ||||
|     - Real Time Communication: https://www.privacyguides.org/en/real-time-communication/ | ||||
|     - Types of Communication Networks: https://www.privacyguides.org/en/advanced/communication-network-types/ | ||||
| tags: | ||||
|     - Instant Messengers | ||||
| description: Wire has been removed from Privacy Guides' recommendations following their acquisition by a US holding company and VC investments. | ||||
| schema_type: NewsArticle | ||||
| --- | ||||
| # Delisting Wire From Privacy Guides | ||||
|  | ||||
|  | ||||
|  | ||||
| It has recently come to the attention of the *Privacy Guides* team that **Wire**, the popular end-to-end encryption messaging platform [has been sold or moved to a US company](https://web.archive.org/web/20201128215737/https://forum.privacytools.io/t/wire-swiss-gmbh-is-now-owned-by-a-usa-holding-company/1932). After a week of questioning, Wire finally confirmed they had changed holding companies and would now be a US based company in a move they called “simple and pragmatic,” as they worked to expand their foothold in the enterprise market. This also came alongside the news that Wire had accepted more than $8 million in Venture Capital (VC) funding from Morpheus Ventures, as well as other investors.<!-- more --> | ||||
|  | ||||
| Morpheus Ventures holds a [portfolio](https://web.archive.org/web/20201128215737/https://morpheus.com/portfolio/) including companies in healthcare, voice AI, life insurance, and retail customer data analytics: All sectors that have historically used invasive data collection methods to survive. Why would a VC with a portfolio centered on consumer data want to invest in a company whose mission claims to protect that very same information? | ||||
|  | ||||
| Earlier this year, Wire announced they had entered a partnership with [FedResults](https://web.archive.org/web/20201128215737/https://www.globenewswire.com/news-release/2019/07/10/1880912/0/en/Wire-and-FedResults-Partner-to-Offer-End-to-End-Encrypted-Collaboration-Platform-to-Government-Agencies.html), in a move that would bring Wire's secure messaging platform to US federal agencies. This raised a few eyebrows, but did not alarm the privacy community as Wire remained Swiss based and beholden to Switzerland's strict privacy laws. Today however, while much of Wire's business will continue to be run out of their Swiss offices, with new US-based ownership it is not entirely clear how much jurisdiction the United States will have over Wire data. | ||||
|  | ||||
| This is alarming because it is well known that Wire [stores unencrypted metadata](https://web.archive.org/web/20201128215737/https://www.vice.com/en_us/article/gvzw5x/secure-messaging-app-wire-stores-everyone-youve-ever-contacted-in-plain-text) for every user. | ||||
|  | ||||
| In an interview with [TechCrunch](https://web.archive.org/web/20201128215737/https://techcrunch.com/2019/11/13/messaging-app-wire-confirms-8-2m-raise-responds-to-privacy-concerns-after-moving-holding-company-to-the-us/), Wire CEO Morten Brøgger said of privacy laws: “We are in Switzerland, which has the best privacy laws in the world” — it’s subject to Europe’s General Data Protection Regulation framework (GDPR) on top of its own local laws — “and Wire now belongs to a new group holding, but there no change in control.” [sic] | ||||
|  | ||||
| Even if he is correct, the move and statement do bring up further questions. With Wire now being a US company with contracts partnering it with US federal authorities, will those authorities now have leverage to compel Wire to give up metadata on users? Wire has investors to answer to and will not be able to risk losing large deals with clients like the US federal government. This is of course a hypothetical situation, but one to be considered nonetheless as we decide which services to recommend on [*Privacy Guides*](https://www.privacyguides.org/en/tools/). | ||||
|  | ||||
| Wire also quietly made an adjustment to its own privacy policy. A [previous version](https://web.archive.org/web/20180324221043/https://wire.com/en/legal/#privacy-7) of the policy (July 18, 2017) stated it would only share user data when required by law. Now (Updated September 1, 2018), it reads they will share user data when "necessary." What does necessary mean, and necessary to whom? Necessary to law enforcement, shareholders, or advertisers? The word "necessary" is an alarming change because "necessary" is purposefully vague terminology that could conceivably be used as a tool to justify any action. This change doesn't leave the user with much confidence as to when the company may share your data. | ||||
|  | ||||
| Yet another red flag, and one of the more important ones to us, was is that Wire decided not to disclose this policy change to its users, and when asked why, Brøgger was flippant in his response, stating: “Our evaluation was that this was not necessary. Was it right or wrong? I don’t know.” | ||||
|  | ||||
| We feel we do know, and the answer was that it was wrong. Privacy and security are not built solely on strong technology, but on trust. Yes, we can review Wire's open source code on GitHub, but we can't ever be sure that code is the same exact code that runs on their servers in practice. Yet, we have trusted them in the past because Wire had built a trustworthy reputation for themselves. We now feel that Wire has lost this reputation. By deciding to withhold information regarding its ownership and policies from its users, Wire has broken the trust our community has placed in it, and worse yet sounds almost dismissive of the worries voiced by the privacy community that had long held them in high regard. | ||||
|  | ||||
| Because of these ongoing concerns, and this break in trust in Wire's organization, *Privacy Guides* has made the decision to remove Wire from its recommendations. It is worth noting that does not necessarily mean Wire is unsafe, but we believe it is our duty to recommend products that we as a team feel comfortable standing behind. We need to believe in the security, privacy, and integrity of our recommendations, and we no longer feel we can do that with Wire at this time. | ||||
|  | ||||
| --- | ||||
|  | ||||
| **2023-10-23:** This post has been edited to reflect the team's move from [PrivacyTools](https://www.privacyguides.org/en/about/privacytools/) to Privacy Guides. | ||||
							
								
								
									
										72
									
								
								blog/posts/firefox-privacy-2021-update.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,72 @@ | ||||
| --- | ||||
| date: | ||||
|     created: 2021-12-01 | ||||
| categories: | ||||
|     - Reviews | ||||
| authors: | ||||
|     - dngray | ||||
| links: | ||||
|     - 'Desktop Browsers<br><small>Firefox</small>': https://www.privacyguides.org/desktop-browsers/#firefox | ||||
| tags: | ||||
|     - Browsers | ||||
|     - Firefox | ||||
| license: CC0 | ||||
| schema_type: AnalysisNewsArticle | ||||
| --- | ||||
| # Firefox Privacy: 2021 Update | ||||
|  | ||||
|  | ||||
|  | ||||
| A lot changed between 2019 and now, not least in regards to Firefox. Since our last post, Mozilla has [improved](https://blog.mozilla.org/en/products/firefox/latest-firefox-rolls-out-enhanced-tracking-protection-2-0-blocking-redirect-trackers-by-default/) privacy with [Enhanced Tracking Protection (ETP)](https://blog.mozilla.org/en/products/firefox/firefox-now-available-with-enhanced-tracking-protection-by-default/). Earlier this year Mozilla introduced [Total Cookie Protection](https://blog.mozilla.org/security/2021/02/23/total-cookie-protection/) (Dynamic First Party Isolation dFPI). This was then further tightened with [Enhanced Cookie Clearing](https://blog.mozilla.org/security/2021/08/10/firefox-91-introduces-enhanced-cookie-clearing/). We’re also looking very forward to [Site Isolation](https://blog.mozilla.org/security/2021/05/18/introducing-site-isolation-in-firefox/) (code named Fission) being enabled by default in the coming releases.<!-- more --> | ||||
|  | ||||
| Now that so many privacy features are built into the browser, there is little need for extensions made by third-party developers. Accordingly, we have updated our very outdated [browser](https://www.privacyguides.org/desktop-browsers/) section. If you’ve got an old browser profile we suggest **creating a new one**. Some of the old advice may make your browser *more* unique. | ||||
|  | ||||
| ## Privacy Tweaks “about:config” | ||||
|  | ||||
| We’re no longer recommending that users set `about:config` switches manually. Those switches need to be up to date and continuously maintained. They should be studied before blindly making modifications. Sometimes their behaviour changes in between Firefox releases, is superseded by other keys or they are removed entirely. We do not see any point in duplicating the efforts of the community [Arkenfox](https://github.com/arkenfox/user.js) project. Arkenfox has very good documentation in their [wiki](https://github.com/arkenfox/user.js/wiki) and we use it ourselves. | ||||
|  | ||||
| ## LocalCDN and Decentraleyes | ||||
|  | ||||
| These extensions aren’t required with Total Cookie Protection (TCP), which is enabled if you’ve set Enhanced Tracking Protection (ETP) to **Strict**. | ||||
|  | ||||
| Replacing scripts on CDNs with local versions is not a comprehensive solution and is a form of [enumeration of badness](https://www.ranum.com/security/computer_security/editorials/dumb/). While it may work with some scripts that are included it doesn’t help with most other third-party connections. | ||||
|  | ||||
| CDN extensions never really improved privacy as far as sharing your IP address was concerned and their usage is fingerprintable as this Tor Project developer [points out](https://gitlab.torproject.org/tpo/applications/tor-browser/-/issues/22089#note_2639603). They are the wrong tool for the job and are not a substitute for a good VPN or Tor. Its worth noting the [resources](https://git.synz.io/Synzvato/decentraleyes/-/tree/master/resources) for Decentraleyes are hugely out of date and would not be likely used anyway. | ||||
|  | ||||
| ## NeatURLs and ClearURLS | ||||
|  | ||||
| Previously we recommended ClearURLs to remove tracking parameters from URLs you might visit. These extensions are no longer needed with uBlock Origin’s [`removeparam`](https://github.com/gorhill/uBlock/wiki/Static-filter-syntax#removeparam) feature. | ||||
|  | ||||
| ## HTTPS Everywhere | ||||
|  | ||||
| The EFF announced back in September they were [deprecating HTTPS-Everywhere](https://www.eff.org/deeplinks/2021/09/https-actually-everywhere) as most browsers now have an HTTPS-Only feature. We are pleased to see privacy features built into the browser and Firefox 91 introduced [HTTPS by Default in Private Browsing](https://blog.mozilla.org/security/2021/08/10/firefox-91-introduces-https-by-default-in-private-browsing/). | ||||
|  | ||||
| ## Multi Account Containers and Temporary Containers | ||||
|  | ||||
| Container extensions aren’t as important as they used to be for privacy now that we have [Total Cookie Protection](https://blog.mozilla.org/security/2021/02/23/total-cookie-protection/). | ||||
|  | ||||
| Multi Account Container will still have some use if you use [Mozilla VPN](https://en.wikipedia.org/wiki/Mozilla_VPN) as it is going to be [integrated](https://github.com/mozilla/multi-account-containers/issues/2210) allowing you to configure specified containers to use a particular VPN server. Another use might be if you want to login to multiple accounts on the same domain. | ||||
|  | ||||
| ## Just-In-Time Compilation (JIT) | ||||
|  | ||||
| What is “Disable JIT” in Bromite? This option disables the JavaScript performance feature [JIT](https://en.wikipedia.org/wiki/Just-in-time_compilation). It can increase security but at the cost of performance. Those trade-offs vary wildly and are explored in [this](https://microsoftedge.github.io/edgevr/posts/Super-Duper-Secure-Mode/) publication by Johnathan Norman from the Microsoft Edge team. This option is very much a security vs performance option. | ||||
|  | ||||
| ## Mozilla browsers on Android | ||||
|  | ||||
| We don’t recommend any Mozilla based browsers on Android. This is because we don’t feel that [GeckoView](https://mozilla.github.io/geckoview) is quite as secure as it could be as it doesn’t support [site isolation](https://hacks.mozilla.org/2021/05/introducing-firefox-new-site-isolation-security-architecture), soon to be coming in desktop browsers or [isolated processes](https://bugzilla.mozilla.org/show_bug.cgi?id=1565196). | ||||
|  | ||||
| We also noticed that there isn’t an option for [HTTPS-Only mode](https://github.com/mozilla-mobile/fenix/issues/16952#issuecomment-907960218). The only way to get something similar is to install the [deprecated](https://www.eff.org/deeplinks/2021/09/https-actually-everywhere) extension [HTTPS Everywhere](https://www.eff.org/https-everywhere). | ||||
|  | ||||
| There are places which Firefox on Android shines for example browsing news websites where you may want to *partially* load some JavaScript (but not all) using medium or hard [blocking mode](https://github.com/gorhill/uBlock/wiki/Blocking-mode). The [reader view](https://support.mozilla.org/en-US/kb/view-articles-reader-view-firefox-android) is also pretty cool. We expect things will change in the future, so we’re keeping a close eye on this. | ||||
|  | ||||
| ## Fingerprinting | ||||
|  | ||||
| Firefox has the ability to block known third party [fingerprinting resources](https://blog.mozilla.org/security/2020/01/07/firefox-72-fingerprinting/). Mozilla has [advanced protection](https://support.mozilla.org/kb/firefox-protection-against-fingerprinting) against fingerprinting (RFP is enabled with Arkenfox). | ||||
|  | ||||
| We do not recommend extensions that promise to change your [browser fingerprint](https://blog.torproject.org/browser-fingerprinting-introduction-and-challenges-ahead/). Some of those extensions [are detectable](https://www.cse.chalmers.se/~andrei/codaspy17.pdf) by websites through JavaScript and [CSS](https://hal.archives-ouvertes.fr/hal-03152176/file/style-fingerprinting-usenix.pdf) methods, particularly those which inject anything into the web content. | ||||
|  | ||||
| This includes **all** extensions that try to change the user agent or other browser behaviour to prevent fingerprinting. We see these often recommended on Reddit and would like to say that they will likely make you more unique and can be circumvented. Arkenfox has [a good list](https://github.com/arkenfox/user.js/wiki/4.1-Extensions) of extensions you could use, and a list of ones you [needn't bother with](https://github.com/arkenfox/user.js/wiki/4.1-Extensions#-dont-bother). We also like to say testing sites which show you how unique you are in a set of users are often using hugely tainted results that are not indicative of real-world usage. | ||||
|  | ||||
| ---------- | ||||
|  | ||||
| *Special thanks to [Thorin-Oakenpants](https://github.com/Thorin-Oakenpants) and [Tommy](https://tommytran.io) for their help with providing advice and further documentation during the research phase.* | ||||
							
								
								
									
										154
									
								
								blog/posts/firefox-privacy.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,154 @@ | ||||
| --- | ||||
| date: | ||||
|     created: 2019-11-09 | ||||
| categories: | ||||
|     - Reviews | ||||
| authors: | ||||
|     - jonah | ||||
| links: | ||||
|     - posts/firefox-privacy-2021-update.md | ||||
| tags: | ||||
|     - Browsers | ||||
|     - Firefox | ||||
| license: BY-SA | ||||
| schema_type: AnalysisNewsArticle | ||||
| --- | ||||
| # Firefox Privacy: Tips and Tricks for Better Browsing | ||||
|  | ||||
|  | ||||
|  | ||||
| Mozilla Firefox is one of the most popular web browsers around, and for good reason. It's fast, secure, open-source, and it's backed by an organization that actually respects your privacy. Unlike many other Chrome alternatives and forks, it has a massive development team behind it that publishes new updates on a constant, regular basis. Regular updates doesn't only mean shiny new features, it means you'll also receive security updates that will keep you protected as you browse the web.<!-- more --> | ||||
|  | ||||
| Because of all of this, [we recommend Firefox](https://www.privacyguides.org/desktop-browsers/#firefox) as our general-purpose browser for most users. It's the best alternative to Chrome and Edge for privacy conscious individuals. | ||||
|  | ||||
| Firefox is fantastic out of the box, but where it really shines is customizability. By adjusting Firefox privacy settings and using helpful add-ons, you can increase your privacy and security even further. Making those changes is what we're going to go over in this Firefox privacy guide. | ||||
|  | ||||
| Before we get started, there's a couple things that should be noted that are not only applicable to this guide, but privacy in general: | ||||
|  | ||||
| ## Considerations | ||||
|  | ||||
| Protecting your privacy online is a tricky proposition, there are so many factors to take into consideration on an individual basis for any one guide or site to cover comprehensively. You will need to take into account things like threat modeling and your general preferences before making any changes or following any recommendations. | ||||
|  | ||||
| ### Threat Modeling | ||||
|  | ||||
| What is [threat modeling](https://www.privacyguides.org/basics/threat-modeling/)? Consider who you're trying to keep your data hidden from. Do you need to keep your information hidden from the government, or just the average stranger? Maybe you are just looking to alternatives to Big Tech like Google and Facebook. You'll also want to consider how much time and resources you want to spend hiding your data from those "threats". Some solutions might not be feasible from a financial or time standpoint and you'll have to make compromises. Taking all those questions into account creates a basic threat model for you to work with. | ||||
|  | ||||
| We want to publish a more complete guide on threat modeling in the future, so stay tuned to this blog for further updates. But for now, just keep those thoughts in the back of your mind as we go through this article. Not every solution might be for you, or conversely you may need to pay more attention to certain areas we aren't able to cover completely. | ||||
|  | ||||
| ### Browser Fingerprinting | ||||
|  | ||||
| Another consideration is your browser's fingerprint. When you visit a web page, your browser voluntarily sends information about its configuration, such as available fonts, browser type, and add-ons. If this combination of information is unique, it may be possible to identify and track you without using more common tracking tools, like cookies. | ||||
|  | ||||
| That's right, add-ons contribute to your fingerprint. Another thing a lot of people miss when they are setting up their browser is that more is not always the best solution to their problems. You don't need to use every add-on and tweak we recommend installed, and the more you configure the greater chance there is that your browser will appear more unique to websites. Think about your specific situation and pick and choose the add-ons and tweaks we recommend only if you think they will help you. | ||||
|  | ||||
| ## Firefox Privacy Settings | ||||
|  | ||||
| We'll start off with the easy solutions. Firefox has a number of privacy settings built in, no add-ons necessary! Open your Options page (Preferences on macOS) and we'll go through them one at a time. | ||||
|  | ||||
| ### DNS over HTTPS | ||||
|  | ||||
| DNS (or the Domain Name System) is what your browser uses to turn domain names like `privacyguides.org` into IP addresses like `65.109.20.157`. Because computers can only make connections to IP addresses, it's necessary to use DNS every time you visit a new domain. But DNS is unencrypted by default, that means everyone on your network (including your ISP) can view what domains you're looking up, and in some situations even change the IP answers to redirect you to their own websites! Encrypting your DNS traffic can shield your queries and add some additional protection to your browsing. | ||||
|  | ||||
| Encrypted DNS takes many forms: DNS over HTTPS (DoH), DNS over TLS, DNSCrypt, etc., but they all accomplish the same thing. They keep your DNS queries private from your ISP, and they make sure they aren't tampered with in transit between your DNS provider. Fortunately, Firefox recently added native DoH support to the browser. On the **General** page of your preferences, scroll down to and open **Network Settings**. At the bottom of the window you will be able to select "Enable DNS over HTTPS" and choose a provider. | ||||
|  | ||||
| Keep in mind that by using DoH you're sending all your queries to a single provider, probably Cloudflare unless you choose [another provider](https://www.privacyguides.org/dns/) that supports DNS over HTTPS. While it may add some privacy protection from your ISP, you're only shifting that trust to the DoH provider. Make sure that's something you want to do. | ||||
|  | ||||
| It should also be noted that even with DoH, your ISP will still be able to see what domain you're connecting to because of a technology called Server Name Indication (SNI). Until SNI is encrypted as well, there's no getting around it. Encrypted SNI (eSNI) is in the works — and can actually be [enabled on Firefox](https://blog.cloudflare.com/encrypt-that-sni-firefox-edition/) today — but it only works with a small number of servers, mainly ones operated by Cloudflare, so its use is limited currently. Therefore, while DoH provides some additional privacy and integrity protections, its use as a privacy tool is limited until other supplemental tools like eSNI and [DNSSEC](https://www.icann.org/resources/pages/dnssec-what-is-it-why-important-2019-03-05-en) are finalized and implemented. | ||||
|  | ||||
| ### Change Your Search Engine | ||||
|  | ||||
| This is an easy one. In the **Search** tab, change your **Default Search Engine** to something other than Google. Out of the built-in options, DuckDuckGo is the most privacy respecting service, but there's a number of [search engines we would recommend](https://www.privacyguides.org/search-engines/) that can be easily installed as well. | ||||
|  | ||||
| ### Enhanced Tracking Protection | ||||
|  | ||||
| Now we'll delve into the biggest set of options for people like us, Firefox's **Privacy & Security** tab. First up is their **Enhanced Tracking Protection**. This set of filters is set to Standard by default, but we'll want to change it to Strict for more comprehensive coverage. | ||||
|  | ||||
| In rare occasions, Strict browsing protections might cause some of the websites you visit to not function properly. But there's no need to worry! If you suspect the Strict browsing protection is breaking a website you visit frequently, you can disable it on a site by site basis with the shield icon in the address bar. | ||||
|  | ||||
| Disabling Enhanced Tracking Protection will of course decrease your privacy on that site, so you will have consider whether that's something you are willing to compromise on, on a site-by-site basis. | ||||
|  | ||||
| Another benefit of Firefox's Enhanced Tracking Protection is that it can actually speed up your browsing! Advertising networks and social media embeds can sometimes make your browser download huge files just to show an ad or a like button, and blocking those out trims the fat, in a sense. | ||||
|  | ||||
| ### Disabling Telemetrics | ||||
|  | ||||
| When you use Firefox, Mozilla collects information about what you do, what kind of extensions you have installed, and various other aspects of your browser. While they claim to do this in a privacy-respecting way, sending as little data as possible is always preferred from a privacy standpoint, so we would go ahead and uncheck all the boxes under **Firefox Data Collection and Use** just to be safe. | ||||
|  | ||||
| ### Clearing Cookies and Site Data | ||||
|  | ||||
| This one is for more advanced users, so if you don't understand what this is doing you can skip this section. Firefox provides the option to delete all your cookies and site data every time Firefox is closed. Cookies and site data are little pieces of information sites store in your browser, and they have a myriad of uses. They are used for things like keeping you logged in and saving your website preferences, but they also can be used to track you across different websites. By deleting your cookies regularly, your browser will appear clean to websites, making you harder to track. | ||||
|  | ||||
| This will likely log you out of websites quite often, so make sure that's an inconvenience you're willing to put up with for enhanced privacy. | ||||
|  | ||||
| ## Firefox Privacy Add-Ons | ||||
|  | ||||
| Of course, just the browser settings alone won't go quite far enough to protect your privacy. Mozilla has made a lot of compromises in order to provide a more functional browsing experience for the average user, which is completely understandable. But, we can take it even further with some browser add-ons that prevent tracking and make your experience more private and secure. | ||||
|  | ||||
| [We recommend a number of fantastic add-ons](https://www.privacyguides.org/desktop-browsers/#ublock-origin) for Firefox, nine at the time of writing, but they aren't all necessary for everyone. Some of them provide redundant functionality to each other, and some of them accomplish similar tasks to the settings we've enabled above. | ||||
|  | ||||
| When you are installing add-ons for Firefox, consider whether you actually need them for your personal browsing. Remember that fingerprinting warning from earlier? Adding as many extensions as possible might make you stand out more, which is not the goal. | ||||
|  | ||||
| Keeping all that in mind, there are three add-ons I would consider necessary for virtually every user: | ||||
|  | ||||
| - uBlock Origin | ||||
| - HTTPS Everywhere | ||||
| - Decentraleyes | ||||
|  | ||||
| Out of the box, these add-ons only complement the settings we've described in this article already, and they have sane defaults that won't break the sites you visit. | ||||
|  | ||||
| ### uBlock Origin | ||||
|  | ||||
| [**uBlock Origin**](https://addons.mozilla.org/en-US/firefox/addon/ublock-origin/) is an efficient ad- and tracker-blocker that is easy on memory, and yet can load and enforce thousands more filters than competing blockers. We trust it because it is completely open-source. Additionally, unlike its competitors it has no monetization strategy: There's no "Acceptable" ads program or a similar whitelist like many other adblockers feature. | ||||
|  | ||||
| ### HTTPS Everywhere | ||||
|  | ||||
| HTTPS is the secure, encrypted version of HTTP. When you see an address starting with `https://` along with the padlock in your browser's address bar, you know that your connection to the website is completely secure. This is of course important when you're logging into websites and sending your passwords and emails in a form. But it also prevents people on your network and your ISP from snooping in on what you're reading, or changing the contents of an unencrypted webpage to whatever they want. | ||||
|  | ||||
| Therefore, [**HTTPS Everywhere**](https://www.eff.org/https-everywhere) is a must-have extension, all it does is upgrade your HTTP connections to HTTPS wherever possible. And because it works silently in the background, you probably will never notice it! We trust HTTPS Everywhere because it is completely open-source, and is developed by the Electronic Frontier Foundation, a non-profit dedicated to private and secure technologies. | ||||
|  | ||||
| Of course, it only works with sites that support HTTPS on the server's side, so you'll still need to keep an eye on your address bar to make sure you're securely connected. But fortunately more and more websites have implemented HTTPS thanks to the advent of free certificates from organizations like Let's Encrypt. | ||||
|  | ||||
| ### Decentraleyes | ||||
|  | ||||
| When you connect to many websites, your browser is most likely making connections to a myriad of "Content Delivery Networks" like Google Fonts, Akamai, and Cloudflare, to download fonts and Javascript that make the website run. This generally makes websites look and feel better, but it means you're constantly making connections to these servers, allowing them to build a fairly accurate tracking profile of you. | ||||
|  | ||||
| [**Decentraleyes**](https://addons.mozilla.org/en-US/firefox/addon/decentraleyes) works by impersonating those CDNs locally in your browser. When a website wants to download a program like jQuery, instead of connecting to a remote CDN Decentraleyes will serve the file from its own cache of files. This means that you'll won't have to make remote CDN connections for the files that Decentraleyes supports, and therefore the remote CDNs can't track your browser. Because everything is stored locally instead of on a far away server, Decentraleyes has the added benefit of speeding up your browsing as well. Everything happens instantly, and you won't see a difference in the websites you visit. | ||||
|  | ||||
| ### Additional Privacy Add-Ons | ||||
|  | ||||
| There is of course more functionality that can be achieved at the expense of more time spent configuring your browser and reduced website functionality. If you're looking for the most privacy options possible however, they may be for you. Check out our [desktop browsers recommendations page](https://www.privacyguides.org/desktop-browsers/) for further information and additional resources. | ||||
|  | ||||
| ## More Privacy Functionality | ||||
|  | ||||
| Firefox has developed a number of other privacy tools that can be used to enhance your privacy or security. They may be worth looking into, but they have some drawbacks that would prevent me from recommending them outright. | ||||
|  | ||||
| ### Firefox Private Network | ||||
|  | ||||
| Firefox Private Network is a new extension developed by Mozilla that serves as a [Virtual Private Network](https://www.privacyguides.org/basics/vpn-overview/) (VPN), securing you on public WiFi networks and other situations where you might trust Mozilla more than the ISP or network administrator. It is free in beta, but will likely be available at some subscription pricing once the test pilot ends. | ||||
|  | ||||
| Firefox Private Network is still just a VPN, and there are a number of drawbacks you would want to consider before using it. We wrote an entire article on [choosing a VPN provider](https://www.jonaharagon.com/posts/choosing-a-vpn/) that is worth a read, but it boils down to the fact that your VPN provider will be able to see your web traffic. All you are accomplishing is shifting the trust from your network to the VPN provider, in this case *Cloudflare*, the operators behind this service. | ||||
|  | ||||
| Additionally, unlike a traditional VPN, only data through the Firefox browser is protected, not every app on your machine. This means that it won't adequately protect you from many of the threats people typically want to protect against when they use a VPN, like IP leaks. | ||||
|  | ||||
| And finally, Cloudflare and Mozilla are both US companies. There are a number of concerns with entrusting internet traffic to the US and other fourteen eyes countries that should not be overlooked. | ||||
|  | ||||
| If you require a Virtual Private Network, we would look elsewhere. There are a number of [recommended providers](https://www.privacyguides.org/vpn/) like Mullvad that will provide a better experience at a low cost. | ||||
|  | ||||
| ### Multi-Account Containers | ||||
|  | ||||
| Mozilla has an in-house add-on called [Multi-Account Containers](https://support.mozilla.org/en-US/kb/containers) that allows you to isolate websites from each other. For example, you could have Facebook in a container separate from your other browsing. In this situation, Facebook would only be able to set cookies with your profile on sites within the container, keeping your other browsing protected. | ||||
|  | ||||
| A containers setup may be a good alternative to techniques like regularly deleting cookies, but requires a lot of manual intervention to setup and maintain. If you want complete control of what websites can do in your browser, it's definitely worth looking into, but we wouldn't call it a necessary addition by any means. | ||||
|  | ||||
| ## Additional Resources | ||||
|  | ||||
| [Desktop Browsers (Privacy Guides)](https://www.privacyguides.org/desktop-browsers/) — Our comprehensive set of recommendations for browsers and tweaks you can make to enhance your privacy is a great next step for more advanced users looking to protect their privacy online. | ||||
|  | ||||
| [arkenfox user.js](https://github.com/arkenfox/user.js) — For more advanced users, the arkenfox user.js  is a "configuration file that can control hundreds of Firefox settings [...] which aims to provide as much privacy and enhanced security as possible, and to reduce tracking and fingerprinting as much as possible - while minimizing any loss of functionality and breakage". | ||||
|  | ||||
| [Mozilla's Privacy Policy](https://www.mozilla.org/en-US/privacy/) — Of course, we always recommend reading through the privacy statement of any organization you deal with, and Mozilla is no exception. | ||||
|  | ||||
| ## Firefox Privacy Summary | ||||
|  | ||||
| In conclusion, we believe that Firefox is the most promising browser for privacy-conscious individuals. The non-profit behind it seems truly dedicated to promoting user control and privacy, and the good defaults coupled with the sheer customizability of the browser allow you to truly protect your information when you browse the web. | ||||
|  | ||||
| For more Firefox privacy-related information, or for recommendations for non-desktop platforms, give our full page on [web browsers](https://www.privacyguides.org/desktop-browsers/) a read. | ||||
							
								
								
									
										81
									
								
								blog/posts/grapheneos-or-calyxos.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,81 @@ | ||||
| --- | ||||
| date: | ||||
|     created: 2022-04-21 | ||||
| authors: | ||||
|     - contributors | ||||
| categories: | ||||
|     - Opinion | ||||
| tags: | ||||
|     - GrapheneOS | ||||
|     - CalyxOS | ||||
| links: | ||||
|     - General Android Overview: https://www.privacyguides.org/android/overview/ | ||||
|     - Android Recommendations: https://www.privacyguides.org/android/ | ||||
| license: BY-SA | ||||
| robots: nofollow, max-snippet:-1, max-image-preview:large | ||||
| schema_type: OpinionNewsArticle | ||||
| --- | ||||
| # Should You Use GrapheneOS or CalyxOS? | ||||
|  | ||||
| GrapheneOS and CalyxOS are often compared as similar options for people looking for an alternative Android OS for their Pixel devices. Below are some of the reasons why we recommend GrapheneOS over CalyxOS.<!-- more --> | ||||
|  | ||||
| ## Update Frequency | ||||
|  | ||||
| CalyxOS has a track record of being slower to apply security and feature updates to its OS and core applications than other custom Android operating systems. Timely security updates are one of the most important factors to consider when determining whether an OS is secure enough for regular use, which is a requirement for privacy. | ||||
|  | ||||
| In contrast to that, GrapheneOS manages to stay close to upstream and in some cases even [deliver updates before the stock OS does](https://grapheneos.org/features#more-complete-patching). | ||||
|  | ||||
| As an example, [GrapheneOS's first Android 12 release](https://grapheneos.org/releases#2021102020) was in October 2021, whereas [CalyxOS moved to Android 12](https://calyxos.org/news/2022/01/19/android-12-changelog/) in January 2022. | ||||
|  | ||||
| ## Sandboxed Google Play vs Privileged microG | ||||
|  | ||||
| When Google Play Services are used on GrapheneOS, they are confined using the highly restrictive, default [`untrusted_app`](https://source.android.com/security/selinux/concepts) [SELinux](https://en.wikipedia.org/wiki/Security-Enhanced_Linux) domain. As a result, you have full control as to what these apps can access via permissions, just like any other app you install. Additionally, you can selectively choose which profile(s) to install the Sandboxed Google Play in. | ||||
|  | ||||
| microG is a partially open-source re-implementation of Google Play Services.[^1] On CalyxOS, it runs in the highly privileged [`system_app`](https://source.android.com/security/selinux/concepts) SELinux domain like regular Google Play Services, and it uses [signature spoofing](https://github.com/microg/GmsCore/wiki/Signature-Spoofing) to masquerade as Google Play Services. This is less secure than Sandboxed Google Play's approach, which does not need access to sensitive system APIs. | ||||
|  | ||||
| When using Sandboxed Google Play, you have the option to reroute location requests to the Play Services API back to the OS location API, which uses satellite based location services. With microG, you have the option to choose between different backend location providers, including *shifting trust* to another location backend, like Mozilla; using [DejaVu](https://github.com/n76/DejaVu), a location backend that locally collects and saves RF-based location data to an offline database which can be used when GPS is not available; or to simply not use a network location backend at all. | ||||
|  | ||||
| Network location providers like Play Services or Mozilla rely the on the MAC addresses of surrounding WiFi access points and Bluetooth devices being submitted for location approximation. Choosing a network location like Mozilla to use with microG provides little to no privacy benefit over Google because you are still submitting the same data and trusting them to not profile you. | ||||
|  | ||||
| Local RF location backends like DejaVu require that the phone has a working GPS first for the local RF data collected to be useful. This makes them less effective as location providers, as the job of a location provider is to assist location approximation when satellite based services are not working. | ||||
|  | ||||
| If your [threat model](https://www.privacyguides.org/basics/threat-modeling/) requires protecting your location or the MAC addresses of nearby devices, rerouting location requests to the OS location API is probably the best option. The benefit brought by microG's custom location backend is minimal at best when compared to Sandboxed Google Play. | ||||
|  | ||||
| In terms of application compatibility, ==Sandboxed Google Play on GrapheneOS is always going to be more compatible== as it is the same code as what is released by Google. microG is a reimplementation of these services. As a result, it only supports the various parts that have been reimplemented, meaning some things such as [Google Play Games](https://play.google.com/googleplaygames) and [In-app Billing API](https://developer.android.com/google/play/billing) are not yet supported. | ||||
|  | ||||
| Larger apps, especially games, require [Play Asset Delivery](https://android-developers.googleblog.com/2020/06/introducing-google-play-asset-delivery.html) to be installed, which is currently not implemented in microG. Authentication using [FIDO](https://www.privacyguides.org/basics/multi-factor-authentication#fido-fast-identity-online) with online services on Android also relies on Play Services, and does not currently work with microG. | ||||
|  | ||||
| [^1]: It should be noted that microG still uses proprietary Google binaries for some of its components such as DroidGuard. Push notifications, if enabled, still go through Google's servers just like with Play Services. Outside of default microG setups like on CalyxOS, it is possible to run microG in the unprivileged [`untrusted app`](https://source.android.com/security/selinux/concepts) SELinux domain and without the signature spoofing patch. However, microG's functionality and compatibility, which is already not nearly as broad as Sandboxed Google Play, will greatly diminish. | ||||
|  | ||||
| ## Privileged eSIM Activation Application | ||||
|  | ||||
| Currently, eSIM activation is tied to a privileged proprietary application by Google. The app has the `READ_PRIVILEGED_PHONE_STATE` permission, giving Google access to your hardware identifiers such as the IMEI. | ||||
|  | ||||
| On GrapheneOS, the app comes disabled and you can *optionally* enable it after installing Sandboxed Google Play. | ||||
|  | ||||
| On CalyxOS, the app comes installed by default (regardless of whether you choose to have microG or not) and you cannot opt-out. This means that Google still has access to your hardware identifiers regardless of whether or not you need eSIM activation and they can be accessed persistently. | ||||
|  | ||||
| ## Privileged App Extensions | ||||
|  | ||||
| Android 12 comes with special support for seamless app updates with [third-party app stores](https://android-developers.googleblog.com/2020/09/listening-to-developer-feedback-to.html). The popular Free and Open-Source Software (FOSS) repository [F-Droid](https://f-droid.org) doesn't implement this feature and requires a [privileged extension](https://f-droid.org/en/packages/org.fdroid.fdroid.privileged) to be included with the Android distribution in order to have unattended app updates. | ||||
|  | ||||
| CalyxOS includes the [privileged extension](https://f-droid.org/en/packages/org.fdroid.fdroid.privileged), which may lower device security. | ||||
|  | ||||
| On the other hand, GrapheneOS officially recommends [Sandboxed Google Play](https://grapheneos.org/usage#sandboxed-google-play) instead. Many FOSS Android apps are also in Google's Play Store but sometimes they are not (like [NewPipe](https://www.privacyguides.org/frontends#newpipe-android)). In those cases, you can [keep up with updates using RSS](https://www.privacyguides.org/android/#manually-with-rss-notifications). | ||||
|  | ||||
| ## Profiles | ||||
|  | ||||
| GrapheneOS significantly improves [user profiles](https://www.privacyguides.org/android/overview#user-profiles) in [multiple ways](https://grapheneos.org/features#improved-user-profiles), such as increasing the limit of how many profiles you can create (32 instead of the standard 4), allowing you to log out of user profiles, disabling app installation, and notification forwarding. All of these improvements make it so user profiles can be daily driven without sacrificing too much usability. | ||||
|  | ||||
| CalyxOS doesn't feature any improvements to user profiles over AOSP, and instead includes a device controller app so that the [work profile](https://www.privacyguides.org/android/overview#work-profile) can be used without needing to download a third party app such as [Shelter](https://www.privacyguides.org/android/#shelter). However, work profiles are not nearly as flexible (as you're limited to only one) and don't provide the same amount of isolation and security. | ||||
|  | ||||
| ## Additional Hardening | ||||
|  | ||||
| GrapheneOS improves upon [AOSP](https://source.android.com/) security with: | ||||
|  | ||||
| - **Hardened WebView:** Vanadium WebView requires [64-bit](https://en.wikipedia.org/wiki/64-bit_computing) processes on the [WebView](https://developer.android.com/reference/android/webkit/WebView) process and disables legacy [32-bit](https://en.wikipedia.org/wiki/32-bit_computing) processes. It uses hardened compiler options such as [`-fwrapv`](https://gcc.gnu.org/onlinedocs/gcc/Code-Gen-Options.html) and [`-fstack-protector-strong`](https://gcc.gnu.org/onlinedocs/gcc-4.9.3/gcc/Optimize-Options.html), which can help protect against [stack buffer overflows](https://en.wikipedia.org/wiki/Stack_buffer_overflow). [API](https://en.wikipedia.org/wiki/API)s such as the [battery status API](https://chromestatus.com/feature/4537134732017664) are disabled for privacy reasons. All system apps on GrapheneOS use the Vanadium WebView which means that apps which use WebView will also benefit from Vanadium's hardening. The [Vanadium patch set](https://github.com/GrapheneOS/Vanadium) is a lot more comprehensive than CalyxOS's [Chromium patch set](https://gitlab.com/CalyxOS/chromium-patches) which is derived from it. | ||||
| - **Hardened Kernel:** GrapheneOS kernel includes some hardening from the [linux-hardened](https://github.com/GrapheneOS/linux-hardened) project and the [Kernel Self Protection Project (KSPP)](https://kernsec.org/wiki/index.php/Kernel_Self_Protection_Project). CalyxOS uses the [same kernel](https://calyxos.org/docs/development/build/kernel/) as regular Android with some minor modifications. | ||||
| - **Hardened Memory Allocator:** GrapheneOS uses the [hardened malloc](https://github.com/GrapheneOS/hardened_malloc) subproject as its memory allocator. This focuses on hardening against [memory heap corruption](https://en.wikipedia.org/wiki/Memory_corruption). CalyxOS uses the default AOSP [Scudo Malloc](https://source.android.com/devices/tech/debug/scudo), which is generally [less effective](https://twitter.com/danielmicay/status/1033671709197398016). Hardened Malloc has uncovered vulnerabilities in AOSP which have been [fixed](https://github.com/GrapheneOS/platform_system_core/commit/be11b59725aa6118b0e1f0712572e835c3d50746) by GrapheneOS such as [CVE-2021-0703](https://nvd.nist.gov/vuln/detail/CVE-2021-0703). | ||||
| - **Secure Exec Spawning:** GrapheneOS [spawns](https://en.wikipedia.org/wiki/Spawn_(computing)) fresh processes as opposed to using the [Zygote model](https://ayusch.com/android-internals-the-android-os-boot-process) used by AOSP and CalyxOS. The Zygote model weakens [Address Space Layout Randomization](https://en.wikipedia.org/wiki/Address_space_layout_randomization) (ASLR) and is considered [less secure](https://wenke.gtisc.gatech.edu/papers/morula.pdf). Creating [fresh processes](https://grapheneos.org/usage#exec-spawning) is safer but will have some performance penalty when launching a new application. These penalties are not really noticeable unless you have an [old device](https://support.google.com/nexus/answer/4457705) with slow storage such as the Pixel 3a/3a XL as it has [eMMC](https://en.wikipedia.org/wiki/MultiMediaCard#eMMC). | ||||
|  | ||||
| **Please note that these are just a few examples and are not an extensive list of GrapheneOS's hardening**. For a more complete list, please read GrapheneOS' [official documentation](https://grapheneos.org/features). | ||||
							
								
								
									
										53
									
								
								blog/posts/hide-nothing.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,53 @@ | ||||
| --- | ||||
| date: | ||||
|     created: 2022-06-09 | ||||
| categories: | ||||
|     - Opinion | ||||
| authors: | ||||
|     - danarel | ||||
| links: | ||||
|     - posts/move-fast-and-break-things.md | ||||
|     - posts/choosing-the-right-messenger.md | ||||
| tags: | ||||
|     - Government | ||||
| license: BY-SA | ||||
| description: In the wake of the September 11, 2001, attack on the United States, the US government enacted laws that weakened citizen privacy in the name of national emergency. | ||||
| schema_type: OpinionNewsArticle | ||||
| --- | ||||
| # Hide Nothing | ||||
|  | ||||
| In the wake of the September 11, 2001, attack on the United States, the US government enacted laws that weakened citizen privacy in the name of national emergency. This sent up many red flags for human rights and privacy advocates.<!-- more --> | ||||
|  | ||||
| These concerns were met with “if you have nothing to hide, you have nothing to fear.” The argument goes that if you're not doing anything illegal, then these violations of your privacy shouldn't bother you. If you care about privacy, you clearly can't be up to anything good. | ||||
|  | ||||
| On the surface, this seems true to many people – but the reality is very different. We may not have had anything to hide in the immediate aftermath of 9/11, but that was not the only information being sought after by governments. Indeed, following the passage of the Patriot Act in the US, the FBI issued 192,499 [National Security Letters](https://www.aclu.org/other/national-security-letters), meaning they collected the records and online activity of nearly 200,000 people. | ||||
|  | ||||
| In the end it only convicted one person. | ||||
|  | ||||
| Now, many have argued that stopping one terrorist might be worth giving up some security for, but [according](https://www.aclu.org/issues/national-security/privacy-and-surveillance/surveillance-under-patriot-act) to the ACLU, the conviction would have occurred without the Patriot Act. | ||||
|  | ||||
| Many legal actions you take today could be deemed illegal by future laws or future government. In the US today there is discussion around the possibility of Roe v. Wade being overturned, allowing states to outlaw abortions. You may not currently feel the need to hide internet searches, menstrual cycle apps, or donations to women's health clinics today because it's not illegal, but tomorrow that information could be used against you. | ||||
|  | ||||
| In countries were organizing around political dissent is legal, that doesn't mean the government is tracking those taking part and using that information to create informants or infiltrate such groups. Or worse, when or if laws change, using that surveillance to punish those involved. | ||||
|  | ||||
| And even if you break away from the legal aspects, we all have something to hide. You may not be ready to reveal your sexual or gender identity, but your internet usage could potentially do that for you. You don't want to make your bank account public; you have that information to hide. And you can continue to list things about your life you'd just rather not make public, regardless of potential legality. | ||||
|  | ||||
| In July of 2021, a Catholic priest by the name of Jeffrey Burrill lost his job and was forced to resign after data collected through his cell phone showed that he was active on the gay dating app Grindr, and that he had visited multiple gay bars in the area. [According](https://www.washingtonpost.com/religion/2021/07/20/bishop-misconduct-resign-burrill/) to the *Washington Post*: | ||||
|  | ||||
| > “A mobile device correlated to Burrill emitted app data signals from the location-based hookup app Grindr on a near-daily basis during parts of 2018, 2019, and 2020 —– at both his USCCB office and his USCCB-owned residence, as well as during USCCB meetings and events in other cities,” the Pillar reported. | ||||
| > | ||||
| > “The data obtained and analyzed by The Pillar conveys mobile app date signals during two 26-week periods, the first in 2018 and the second in 2019 and 2020. The data was obtained from a data vendor and authenticated by an independent data consulting firm contracted by The Pillar,” the site reported. It did not identify who the vendor was or if the site bought the information or got it from a third party. | ||||
| > | ||||
| > The Pillar story says app data “correlated” to Burrill's phone shows the priest visited gay bars, including while traveling for the USCCB. | ||||
|  | ||||
| While it was not clear who was tracking Burrill's device, the Post went on to say that: | ||||
|  | ||||
| > Privacy experts have long raised concerns about “anonymized” data collected by apps and sold to or shared with aggregators and marketing companies. While the information is typically stripped of obviously identifying fields, like a user's name or phone number, it can contain everything from age and gender to a device ID. It's possible for experts to de-anonymize some of this data and connect it to real people. | ||||
|  | ||||
| While Burrill was without a doubt in violation of his work's own code of conduct, he did decide on his own to be a priest. However, his personal life was not harming others and was just that, his personal life. While the question looms about who was tracking him to begin with and why, the fact it was so easy to do is alarming. | ||||
|  | ||||
| What if Burrill wasn't a priest, but just happened to work for someone who held anti-homosexual views who used this data to out him, humiliate him, and fire him under false pretenses? This data, which should be private could (and likely did in the real-life circumstance) ruin his life. | ||||
|  | ||||
| That is what makes internet privacy so important. It's not hiding nefarious activity, it's that we all have an innate right to our privacy. | ||||
|  | ||||
| You might not feel today that you have anything to hide, but you might not feel that way tomorrow and once something is public, it cannot be made private again. | ||||
							
								
								
									
										81
									
								
								blog/posts/i18n-announcement.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,81 @@ | ||||
| --- | ||||
| date: | ||||
|     created: 2023-02-26 | ||||
| categories: | ||||
|     - Announcements | ||||
| authors: | ||||
|     - freddy | ||||
|     - dngray | ||||
|     - niek-de-wilde | ||||
| tags: | ||||
|     - Privacy Guides | ||||
| license: BY-SA | ||||
| description: It's finally here. After countless requests, Privacy Guides now has translations. | ||||
| schema_type: NewsArticle | ||||
| --- | ||||
| # Privacy Guides Is Now Multilingual | ||||
|  | ||||
| It's finally here. After countless requests, Privacy Guides now has translations. | ||||
|  | ||||
| People have always asked us for translations to other languages because our team and community produces high quality, reliable, honest, and researched content. Our [previous site](https://blog.privacyguides.org/2021/09/14/welcome-to-privacy-guides) never had a system for this. All translations were done manually, and translators would quickly lose interest. Translated sites would be outdated and lay unmaintained on domains that we didn't own. Privacy Guides now has a proper system.<!-- more --> | ||||
|  | ||||
| Our site runs [Material for MkDocs](https://squidfunk.github.io/mkdocs-material/), which supports [internationalization](https://squidfunk.github.io/mkdocs-material/setup/changing-the-language/). This allows us to provide language specific content without the mammoth effort previously required. | ||||
|  | ||||
| ## What we're planning | ||||
|  | ||||
| You can expect translations of this blog – and lots more content. We will add languages to the site when they near completion. That way they can be checked to make sure they maintain the high quality that people have come to expect from the rest of Privacy Guides. | ||||
|  | ||||
| ### Translators | ||||
|  | ||||
| We'd also like to remind everyone you can stay up to date with the main site by looking at [our release page](https://github.com/privacyguides/privacyguides.org/releases), this will show major changes to the main content. You can subscribe with a [News Aggregator](https://www.privacyguides.org/news-aggregators): | ||||
|  | ||||
| - [privacyguides.org (Releases)](https://github.com/privacyguides/privacyguides.org/releases.atom). | ||||
| - [privacyguides.org (Commit log)](https://github.com/privacyguides/privacyguides.org/commits/main.atom) | ||||
| - [blog.privacyguides.org](https://blog.privacyguides.org/feed_rss_created.xml) | ||||
| - [blog.privacyguides.org (Commit log)](https://github.com/privacyguides/blog.privacyguides.org/commits/main.atom) | ||||
|  | ||||
| The blog doesn't have releases, but articles are generally published in a complete state and only updated with minor changes. | ||||
|  | ||||
| Feel free to check out our localization room on Matrix [#pg-i18n:aragon.sh](https://matrix.to/#/%23pg-i18n:aragon.sh) if you have any questions on getting started. You can [find us on Crowdin](https://crowdin.com/project/privacyguides). | ||||
|  | ||||
| Please note that the English version of the site is the primary version, meaning changes occur there first. This means it is still possible that specific languages may be behind. If you notice such an instance please help out. We cannot guarantee the accuracy of all our translations. If you have a suggestion about content specific to your region, please open an issue or pull request to our [main repository](https://github.com/privacyguides/privacyguides.org). | ||||
|  | ||||
| #### Some tips for translators | ||||
|  | ||||
| Crowdin has good documentation and we suggest looking at their [Getting Started](https://support.crowdin.com/crowdin-intro/) guide. Our site is in [Markdown](https://en.wikipedia.org/wiki/Markdown), so it should be easy to chip in. | ||||
|  | ||||
| #### Admonitions | ||||
|  | ||||
| Throughout the site we use MkDocs's [admonitions](https://squidfunk.github.io/mkdocs-material/reference/admonitions/#usage), to show information to readers about the products such as `example`, `warning`, `tip`, etc. | ||||
|  | ||||
| By default when admonitions are used they will have an English string on the site. This can be [customized](https://squidfunk.github.io/mkdocs-material/reference/admonitions/#changing-the-title), without too much effort. For example if you were translating and admonition of type [warning](https://squidfunk.github.io/mkdocs-material/reference/admonitions/#type:warning) to Dutch, this is how you would write it: | ||||
|  | ||||
| ```text | ||||
| !!! warning "Waarschuwing" | ||||
| ``` | ||||
|  | ||||
| Downloads are a [custom admonition](https://squidfunk.github.io/mkdocs-material/reference/admonitions/#custom-admonitions) that we use and you would write that like: | ||||
|  | ||||
| ```text | ||||
| ??? downloads "Downloaden" | ||||
| ``` | ||||
|  | ||||
| The same goes for other types, such as `tip`, `example` etc. Recommendations are also admonitions, but they do not need overriding, because the default has no text, so they are always: | ||||
|  | ||||
| ```text | ||||
| !!! recommendation | ||||
| ``` | ||||
|  | ||||
| #### Translation software | ||||
|  | ||||
| Translation software gets the translation quite reliable. We've found [DeepL](https://www.deepl.com/en/translator) works well however, attention does need to be given that the translated string is correct. | ||||
|  | ||||
| For example: | ||||
|  | ||||
| ```text | ||||
| { align=right } | ||||
| ``` | ||||
|  | ||||
| We have sometimes found that the syntax for inserting an image like above was missing the ` which one you think sounds best. When invalid strings are deleted they are removed from the organization's [translation memory](https://support.crowdin.com/enterprise/translation-memory), meaning that when the source string is seen again, it won't suggest the incorrect translation. | ||||
|  | ||||
| We'd like to thank the [translation team](https://crowdin.com/project/privacyguides/reports/top-members) who spent many hours on translating the content, that we now have. We're going to launch in Dutch, French and Hebrew. | ||||
							
								
								
									
										174
									
								
								blog/posts/integrating-metadata-removal.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,174 @@ | ||||
| --- | ||||
| date: | ||||
|     created: 2022-04-09 | ||||
| categories: | ||||
|     - Tutorials | ||||
| authors: | ||||
|     - contributors | ||||
| links: | ||||
|     - Metadata Removal Tools: https://www.privacyguides.org/data-redaction/ | ||||
| tags: | ||||
|     - macOS | ||||
|     - iOS | ||||
|     - Windows | ||||
| license: BY-SA | ||||
| description: When sharing files, it's important to remove associated metadata. Image files commonly include Exif data, and sometimes photos even include GPS coordinates within its metadata. | ||||
| schema_type: AnalysisNewsArticle | ||||
| --- | ||||
| # Removing Metadata From Your Photos, Videos, and Other Files | ||||
|  | ||||
| When sharing files, it's important to remove associated metadata. Image files commonly include [Exif](https://en.wikipedia.org/wiki/Exif) data, and sometimes photos even include GPS coordinates within its metadata.<!-- more --> | ||||
|  | ||||
| While there are plenty of metadata removal tools, they typically aren't convenient to use. The guides featured here aim to detail how to integrate metadata removal tools in a simple fashion by utilizing easy-to-access system features. | ||||
|  | ||||
| ## macOS | ||||
|  | ||||
| This guide uses the [Shortcuts](https://support.apple.com/guide/shortcuts-mac/intro-to-shortcuts-apdf22b0444c/mac) app to add an [ExifTool](https://www.privacyguides.org/data-redaction#exiftool) script to the *Quick Actions* context menu within Finder. Shortcuts is developed by Apple and bundled in with macOS by default. | ||||
|  | ||||
| Shortcuts is quite intuitive to work with, so if you don't like the behavior demoed here then experiment with your own solution. For example, you could set the shortcut to take a clipboard input instead. The sky's the limit. | ||||
|  | ||||
|  | ||||
|  | ||||
| ### Prerequisites | ||||
|  | ||||
| 1. [Homebrew](https://brew.sh): a package manager. | ||||
|  | ||||
|     ```bash | ||||
|     /bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)" | ||||
|     ``` | ||||
|  | ||||
| 2. ExifTool is a tool for viewing and manipulating image, audio, video, and PDF metadata. | ||||
|  | ||||
|     ```bash | ||||
|     brew install exiftool | ||||
|     ``` | ||||
|  | ||||
| !!! note | ||||
|     You can check if ExifTool is installed by running `exiftool -ver`. You should see a version number. | ||||
|  | ||||
| ### Creating the Shortcut | ||||
|  | ||||
| 1. Open **Shortcuts.app** and create a new shortcut | ||||
|  | ||||
| 2. In the shortcut's options, check **Use as Quick Action** and **Finder** | ||||
|  | ||||
| 3. Set up the retrieval options: | ||||
|  | ||||
|     - Receive **Images, Media, and PDFs** input from **Quick Actions** | ||||
|     - If there is no input select **Continue** | ||||
|  | ||||
| 4. Add the **Run Shell Script** action to the shortcut. You may need to enable **Allow Running Scripts** in Shortcut.app's settings | ||||
|  | ||||
| 5. Set up the shell script action: | ||||
|      - Select **zsh** from the shell list | ||||
|      - Set the input to **Shortcut Input** | ||||
|      - Select **as arguments** for the pass input | ||||
|      - Leave **Run as administrator** unchecked | ||||
|  | ||||
| 6. Use the following as the body of the script: | ||||
|  | ||||
|     ```bash | ||||
|     for f in "$@" | ||||
|     do | ||||
|         exiftool -all= "$f"; | ||||
|     done | ||||
|     ``` | ||||
|  | ||||
|  | ||||
|  | ||||
| !!! tip "Worth Mentioning" | ||||
|     The open-source [ImageOptim](https://imageoptim.com/mac) app integrates into Finder's *Services* context menu by default. While it is primarily an image optimization app, it also removes metadata. | ||||
|  | ||||
| ### Enabling & using the Shortcut | ||||
|  | ||||
| 1. The shortcut will be accessible through **Quick Actions** context menu within Finder. | ||||
|  | ||||
| 2. If you want to reposition the shortcut within the context menu, go to:<br> | ||||
|    **System Preferences** → **Extensions** → **Finder and drag the shortcut's position**. | ||||
|  | ||||
| ## iOS and iPadOS | ||||
|  | ||||
| [Shortcuts](https://support.apple.com/guide/shortcuts/welcome/ios) can be made accessible through the system Share Sheet, making accessing those shortcuts very convenient. This guide will show you how to build a metadata removal shortcut and integrate it into the system *Share Sheet*. | ||||
|  | ||||
| !!! warning | ||||
|     This method of metadata removal is not as comprehensive at removing metadata as utilities like [ExifTool](https://www.privacyguides.org/data-redaction#exiftool) and [mat2](https://www.privacyguides.org/data-redaction#mat2) are. | ||||
|  | ||||
| The lack of *good* metadata removal apps on the App Store is what makes this solution worthwhile. | ||||
|  | ||||
|  | ||||
|  | ||||
| ### Prerequisites | ||||
|  | ||||
| 1. [Shortcuts](https://apps.apple.com/us/app/shortcuts/id915249334) via the App Store. | ||||
|  | ||||
| ### Creating the Shortcut | ||||
|  | ||||
| 1. Create a new Shortcut | ||||
|  | ||||
| 2. Enter the Shortcut's settings and check **Show in Share Sheet** | ||||
|  | ||||
| 3. Add a **Receive** action and set it to receive **Images** from **Share Sheet** | ||||
|  | ||||
| 4. Add an **If** action | ||||
|  | ||||
| 5. Set the **If** action to **Shortcut Input** and **has any value** | ||||
|  | ||||
| 6. Add an **Otherwise** action | ||||
|  | ||||
| 7. Add an **End If** action | ||||
|  | ||||
| 8. Add a **Convert** action and set it to **If Result** and **Match Input** | ||||
|  | ||||
| 9. Finally, add a **Share** action and set that to **Converted Image** | ||||
|  | ||||
| 10. Make sure that you uncheck **preserve metadata** | ||||
|  | ||||
|  | ||||
|  | ||||
| ### Enabling & using the Shortcut | ||||
|  | ||||
| 1. The shortcut should be available through the system Share Sheet. If it is not, then a device restart may be required. | ||||
| 2. Optionally, you can add the shortcut to your home screen. | ||||
|  | ||||
| ## Windows | ||||
|  | ||||
| Windows allows you to place files in a **SendTo** folder which then appear in the *Send to* context menu. This guide will show you how to add an [ExifTool](https://www.privacyguides.org/data-redaction#exiftool) batch script to this menu. | ||||
|  | ||||
|  | ||||
|  | ||||
| ### Prerequisites | ||||
|  | ||||
| 1. ExifTool is a tool for viewing and manipulating image, audio, video, and PDF metadata. We suggest you read the [Installation instructions](https://exiftool.org/install.html#Windows) on the official website. | ||||
|  | ||||
| !!! note | ||||
|     You can check if ExifTool is present in your [PATH](https://www.computerhope.com/issues/ch000549.htm) by running `exiftool -ver` in Command Prompt. You should see a version number. | ||||
|  | ||||
| ### Creating the shortcut | ||||
|  | ||||
| 1. Navigate to `%appdata%\Microsoft\Windows\SendTo` | ||||
|  | ||||
| 2. Right click in the **SendTo** folder and create a new **Text Document** | ||||
|  | ||||
| 3. Name the file `ExifTool.bat` (any name works, however it must end in `.bat`) | ||||
|  | ||||
|     !!! note | ||||
|         You may need to check if [file name extensions](https://support.microsoft.com/en-us/windows/common-file-name-extensions-in-windows-da4a4430-8e76-89c5-59f7-1cdbbc75cb01) are enabled. | ||||
|  | ||||
| 4. Open **ExifTool.bat** in Notepad | ||||
|  | ||||
| 5. Copy the following into the document: | ||||
|  | ||||
|     ```bat | ||||
|     exiftool -fast4 -if "$filepermissions =~ /^.w/" %* | ||||
|     if not errorlevel 0 ( | ||||
|         echo Some files are write protected | ||||
|         exit /b %errorlevel% | ||||
|     ) | ||||
|     exiftool -all= %* | ||||
|     ``` | ||||
|  | ||||
| 6. Save | ||||
|  | ||||
| ### Using the shortcut | ||||
|  | ||||
| 1. Right click a supported file and choose **ExifTool.bat** within the *Send to* context menu. | ||||
							
								
								
									
										204
									
								
								blog/posts/ios-configuration-guide.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,204 @@ | ||||
| --- | ||||
| date: | ||||
|     created: 2022-10-22 | ||||
| categories: | ||||
|     - Tutorials | ||||
| authors: | ||||
|     - mfwmyfacewhen | ||||
|     - jonah | ||||
|     - contributors | ||||
| tags: | ||||
|     - iOS | ||||
| license: BY-SA | ||||
| description: There are a number of privacy and security-related settings you should consider changing in the Settings app on iOS 16. | ||||
| schema_type: AnalysisNewsArticle | ||||
| --- | ||||
| # iOS 16 Privacy Configuration Guide | ||||
|  | ||||
| There are a number of privacy and security-related settings you should consider changing in the **Settings** app on iOS.<!-- more --> | ||||
|  | ||||
| ## iCloud | ||||
|  | ||||
| Apple uses **iCloud** to sync your settings, photos, documents, apps, etc. to your other devices. Some things synced to iCloud are end-to-end encrypted, while others are merely encrypted in transit. You can check [Apple's documentation](https://support.apple.com/en-us/HT202303) for information on which services are E2EE; anything listed as "in transit" or "on server" means it's possible for Apple to access that data without your permission. You should disable anything you don't want backed up to iCloud. | ||||
|  | ||||
| !!! warning | ||||
|  | ||||
|     Despite "Messages in iCloud" being E2EE, enabling iCloud Backup stores a key to unlock iMessage in your device backup, which is **not** E2EE. If you don't want to store a copy of your iMessage keys, disable iCloud Backup. | ||||
|  | ||||
| At the top of the **Settings** app, you'll see your name and profile picture if you are signed in to iCloud. Select that, then **iCloud**, and turn off the switches for any services you don't want to sync to iCloud. You may see third-party apps listed under **Show All** if they sync to iCloud, which you can disable here. For the purposes of this guide, we will only be covering first-party Apple iCloud services: | ||||
|  | ||||
| **iCloud Backup** backs up your phone and app data to Apple's servers. Unfortunately, these backups are not E2EE,[^1] and having them enabled even removes E2EE from some other iCloud services (like iMessage). Instead of iCloud Backup, we recommend making an encrypted backup to your computer using iTunes (Windows) or Finder (macOS). | ||||
|  | ||||
| [^1]: [Reuters - Exclusive: Apple dropped plan for encrypting backups after FBI complained](https://www.reuters.com/article/us-apple-fbi-icloud-exclusive-idUSKBN1ZK1CT) | ||||
|  | ||||
| Select **iCloud Backup** | ||||
|  | ||||
| - [ ] Turn off **Back Up This iPhone** | ||||
|  | ||||
| **Private Relay** is a paid ([**iCloud+**](https://support.apple.com/en-us/HT201318)) proxy service which relays your Safari traffic through two servers: one owned by Apple and one owned by Cloudflare. Because Private Relay is still in beta and it only covers the Safari browser, we recommend you choose a proper [VPN](https://www.privacyguides.org/vpn/) instead. | ||||
|  | ||||
| Select **Private Relay** | ||||
|  | ||||
| - [ ] Turn off **Private Relay (Beta)** | ||||
|  | ||||
| If you already use iCloud Mail, **Hide My Email** is Apple's first-party email aliasing feature. You can use email aliases with Sign In With Apple, for free, or generate unlimited aliases with a paid iCloud+ plan. Hide My Email may be good for iCloud Mail users because it only requires trusting one party (Apple) with your emails, but if you use any other email provider, we recommend [a standalone email aliasing service](https://www.privacyguides.org/email#email-aliasing-services) instead. | ||||
|  | ||||
| ### Media & Purchases | ||||
|  | ||||
| At the top of the **Settings** app, you'll see your name and profile picture if you are signed in to an Apple ID. Select that, then select **Media & Purchases** > **View Account**. | ||||
|  | ||||
| - [ ] Turn off **Personalized Recommendations** | ||||
|  | ||||
| ### Find My | ||||
|  | ||||
| **Find My** is a service that lets you track your Apple devices and share your location with your friends and family. It also allows you to wipe your device remotely in case it is stolen, preventing a thief from accessing your data. Your Find My [location data is E2EE](https://www.apple.com/legal/privacy/data/en/find-my/) when: | ||||
|  | ||||
| - Your location is shared with a family member or friend, and you both use iOS 15 or greater. | ||||
| - Your device is offline and is located by the Find My Network. | ||||
|  | ||||
| Your location data is not E2EE when your device is online and you use Find My iPhone remotely to locate your device. You will have to make the decision whether these trade-offs are worth the anti-theft benefits of Activation Lock. | ||||
|  | ||||
| At the top of the **Settings** app, you'll see your name and profile picture if you are signed in to an Apple ID. Select that, then select **Find My**. Here you can choose whether to enable or disable Find My location features. | ||||
|  | ||||
| ## Airplane Mode | ||||
|  | ||||
| Enabling **Airplane Mode** stops your phone from contacting cell towers. You will still be able to connect to Wi-Fi and Bluetooth, so whenever you are connected to Wi-Fi you can turn this setting on. | ||||
|  | ||||
| ## Wi-Fi | ||||
|  | ||||
| You can enable hardware address randomization to protect you from tracking across Wi-Fi networks. On the network you are currently connected to, press the :material-information: button: | ||||
|  | ||||
| - [x] Turn on **Private Wi-Fi Address** | ||||
|  | ||||
| You also have the option to **Limit IP Address Tracking**. This is similar to iCloud Private Relay but only affects connections to "known trackers." Because it only affects connections to potentially malicious servers, this setting is probably fine to leave enabled, but if you don't want *any* traffic to be routed through Apple's servers, you should turn it off. | ||||
|  | ||||
| ## Bluetooth | ||||
|  | ||||
| **Bluetooth** should be disabled when you aren't using it as it increases your attack surface. Disabling Bluetooth (or Wi-Fi) via the Control Center only disables it temporarily: you must switch it off in Settings for disabling it to remain effective. | ||||
|  | ||||
| - [ ] Turn off **Bluetooth** | ||||
|  | ||||
| ## General | ||||
|  | ||||
| Your iPhone's device name will by default contain your first name, and this will be visible to anyone on networks you connect to. You should change this to something more generic, like "iPhone." Select **About** > **Name** and enter the device name you prefer. | ||||
|  | ||||
| It is important to install **Software Updates** frequently to get the latest security fixes. You can enable **Automatic Updates** to keep your phone up-to-date without needing to constantly check for updates. Select **Software Update** > **Automatic Updates**: | ||||
|  | ||||
| - [x] Turn on **Download iOS Updates** | ||||
| - [x] Turn on **Install iOS Updates** | ||||
| - [x] Turn on **Security Responses & System Files** | ||||
|  | ||||
| **AirDrop** allows you to easily transfer files, but it can allow strangers to send you files you do not want. | ||||
|  | ||||
| - [x] Select **AirDrop** > **Receiving Off** | ||||
|  | ||||
| **AirPlay** lets you seamlessly stream content from your iPhone to a TV; however, you might not always want this. Select **AirPlay & Handoff** > **Automatically AirPlay to TVs**: | ||||
|  | ||||
| - [x] Select **Never** or **Ask** | ||||
|  | ||||
| **Background App Refresh** allows your apps to refresh their content while you're not using them. This may cause them to make unwanted connections. Turning this off can also save battery life, but it may affect an app's ability to receive updated information, particularly weather and messaging apps. | ||||
|  | ||||
| Select **Background App Refresh** and switch off any apps you don't want to continue refreshing in the background. If you don't want any apps to refresh in the background, you can select **Background App Refresh** again and turn it **Off**. | ||||
|  | ||||
| ## Siri & Search | ||||
|  | ||||
| If you don't want anyone to be able to control your phone with Siri when it is locked, you can turn that off here. | ||||
|  | ||||
| - [ ] Turn off **Allow Siri When Locked** | ||||
|  | ||||
| ## Face ID or Touch ID & Passcode | ||||
|  | ||||
| Setting a strong password on your phone is the most important step you can take for physical device security. You'll have to make tradeoffs here between security and convenience: A longer password will be annoying to type in every time, but a shorter password or PIN will be easier to guess. Setting up Face ID or Touch ID along with a strong password can be a good compromise between usability and security. | ||||
|  | ||||
| Select **Turn Passcode On** or **Change Passcode** > **Passcode Options** > **Custom Alphanumeric Code**. Make sure that you create a [secure password](https://www.privacyguides.org/basics/passwords-overview/). | ||||
|  | ||||
| If you wish to use Face ID or Touch ID, you can go ahead and set it up now. Your phone will use the password you set up earlier as a fallback in case your biometric verification fails. Biometric unlock methods are primarily a convenience, although they do stop surveillance cameras or people over your shoulder from watching you input your passcode. | ||||
|  | ||||
| If you use biometrics, you should know how to turn them off quickly in an emergency. Holding down the side or power button and *either* volume button until you see the Slide to Power Off slider will disable biometrics, requiring your passcode to unlock. Your passcode will also be required after device restarts. | ||||
|  | ||||
| On some older devices, you may have to press the power button five times to disable biometrics instead, or for devices with Touch ID you may just have to hold down the power button and nothing else. Make sure you try this in advance so you know which method works for your device. | ||||
|  | ||||
| **Allow Access When Locked** gives you options for what you can allow when your phone is locked. The more of these options you disable, the less someone without your password can do, but the less convenient it will be for you. Pick and choose which of these you don't want someone to have access to if they get their hands on your phone. | ||||
|  | ||||
| - [ ] Turn off **Today View and Search** | ||||
| - [ ] Turn off **Notification Center** | ||||
| - [ ] Turn off **Control Center** | ||||
| - [ ] Turn off **Lock Screen Widgets** | ||||
| - [ ] Turn off **Siri** | ||||
| - [ ] Turn off **Reply with Message** | ||||
| - [ ] Turn off **Home Control** | ||||
| - [ ] Turn off **Wallet** | ||||
| - [ ] Turn off **Return Missed Calls** | ||||
| - [ ] Turn off **USB Accessories** | ||||
|  | ||||
| iPhones are already resistant to brute-force attacks by making you wait long periods of time after multiple failed attempts; however, there have historically been exploits to get around this. To be extra safe, you can set your phone to wipe itself after 10 failed passcode attempts. | ||||
|  | ||||
| !!! warning | ||||
|  | ||||
|     With this setting enabled, someone could intentionally wipe your phone by entering the wrong password many times. Make sure you have proper backups and only enable this setting if you feel comfortable with it. | ||||
|  | ||||
| - [x] Turn on **Erase Data** | ||||
|  | ||||
| ## Privacy | ||||
|  | ||||
| **Location Services** allows you to use features like Find My and Maps. If you don't need these features, you can disable Location Services. Alternatively, you can review and pick which apps can use your location here. Select **Location Services**: | ||||
|  | ||||
| - [ ] Turn off **Location Services** | ||||
|  | ||||
| You can decide to allow apps to request to **track** you here. Disabling this disallows all apps from tracking you with your phone's advertising ID. Select **Tracking**: | ||||
|  | ||||
| - [ ] Turn off **Allow Apps to Request to Track** | ||||
|  | ||||
| You should turn off **Research Sensor & Usage Data** if you don't wish to participate in studies. Select **Research Sensor & Usage Data**: | ||||
|  | ||||
| - [ ] Turn off **Sensor & Usage Data Collection** | ||||
|  | ||||
| **Safety Check** allows you to quickly view and revoke certain people and apps that might have permission to access your data. Here you can perform an **Emergency Reset**, immediately resetting permissions for all people and apps which might have access to device resources, and you can **Manage Sharing & Access** which allows you to go through and customize who and what has access to your device and account resources. | ||||
|  | ||||
| You should disable analytics if you don't wish to send Apple usage data. Select **Analytics & Improvements**: | ||||
|  | ||||
| - [ ] Turn off **Share iPhone Analytics** or **Share iPhone & Watch Analytics** | ||||
| - [ ] Turn off **Share iCloud Analytics** | ||||
| - [ ] Turn off **Improve Fitness+** | ||||
| - [ ] Turn off **Improve Safety** | ||||
| - [ ] Turn off **Improve Siri & Dictation** | ||||
|  | ||||
| Disable **Personalized Ads** if you don't want targeted ads. Select **Apple Advertising** | ||||
|  | ||||
| - [ ] Turn off **Personalized Ads** | ||||
|  | ||||
| **App Privacy Report** is a built-in tool that allows you to see which permissions your apps are using. Select **App Privacy Report**: | ||||
|  | ||||
| - [x] Select **Turn On App Privacy Report** | ||||
|  | ||||
| **Lockdown Mode** is a security setting you can enable to make your phone more resistant to attacks. Be aware that certain apps and features [won't work](https://support.apple.com/en-us/HT212650) as they do normally. | ||||
|  | ||||
| - [x] Select **Turn On Lockdown Mode** | ||||
|  | ||||
| ## Privacy/Security Tips | ||||
|  | ||||
| ### E2EE Calls | ||||
|  | ||||
| Normal phone calls made with the Phone app through your carrier are not E2EE. Both FaceTime Video and FaceTime Audio calls are E2EE, or you can use [another app](https://www.privacyguides.org/real-time-communication/) like Signal. | ||||
|  | ||||
| ### Avoid Jailbreaking | ||||
|  | ||||
| Jailbreaking an iPhone undermines its security and makes you vulnerable. Running untrusted, third-party software could cause your device to be infected with malware. | ||||
|  | ||||
| ### Encrypted iMessage | ||||
|  | ||||
| The color of the message bubble in the Messages app indicates whether your messages are E2EE or not. A blue bubble indicates that you're using iMessage with E2EE, while a green bubble indicates they're using the outdated SMS and MMS protocols. Currently, the only way to get E2EE in Messages is for both parties to be using iMessage on Apple devices. | ||||
|  | ||||
| If either you or your messaging partner have iCloud Backup enabled, the encryption key will be stored on Apple's servers, meaning they can access your messages. Additionally, iMessage's key exchange is not as secure as alternative implementations, like Signal (which allows you to view the recipients key and verify by QR code), so it shouldn't be relied on for particularly sensitive communications. | ||||
|  | ||||
| ### Blacking Out Faces/Information | ||||
|  | ||||
| If you need to hide information in a photo, you can use Apple's built-in tools to do so. Open the photo you want to edit, press edit at the top right corner of the screen, then press the markup symbol at the top right. Press the plus at the bottom right of the screen, then press the rectangle icon. Now, you can place a rectangle anywhere on the image. Make sure to press the shape icon at the bottom left and select the filled-in rectangle. **Don't** use the highlighter to obfuscate information, because its opacity is not quite 100%. | ||||
|  | ||||
| ### Installing Beta Versions of iOS | ||||
|  | ||||
| Apple always makes beta versions of iOS available early for those that wish to help find and report bugs. We don't recommend installing beta software on your phone. Beta releases are potentially unstable and could have undiscovered security vulnerabilities. | ||||
|  | ||||
| ### Before First Unlock | ||||
|  | ||||
| If your threat model includes forensic tools and you want to minimize the chance of exploits being used to access your phone, you should restart your device frequently. The state *after* a reboot but *before* unlocking your device is referred to as "Before First Unlock" (BFU), and when your device is in that state it makes it [significantly more difficult](https://belkasoft.com/checkm8_glossary) for forensic tools to exploit vulnerabilities to access your data. This BFU state allows you to receive notifications for calls, texts, and alarms, but most of the data on your device is still encrypted and inaccessible. This can be impractical, so consider whether these trade-offs make sense for your situation. | ||||
							
								
								
									
										43
									
								
								blog/posts/job-openings.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,43 @@ | ||||
| --- | ||||
| date: | ||||
|     created: 2024-10-28 | ||||
| categories: | ||||
|     - Announcements | ||||
| authors: | ||||
|     - niek-de-wilde | ||||
| links: | ||||
|     - Job Openings: https://www.privacyguides.org/en/about/jobs/ | ||||
| tags: | ||||
|     - Privacy Guides | ||||
| description: Privacy Guides is now hiring for a video content creation position and a journalist position, as well as a 6-month internship. | ||||
| schema_type: NewsArticle | ||||
| --- | ||||
| # Privacy Guides is Hiring | ||||
|  | ||||
| We are thrilled to announce the opening of three new job positions aimed at enhancing our mission of promoting personal privacy and informed digital choices. As a non-profit organization dedicated to empowering individuals with the knowledge and tools they need to navigate the internet in a private manner, we are excited to expand our team with talented individuals who share our vision. They will play a key role in helping us reach new audiences to spread our message in multiple formats, and make sure we are the authoritative source for trustworthy and unbiased consumer privacy resources on the internet.<!-- more --> | ||||
|  | ||||
| ## Content Creator | ||||
|  | ||||
| We're seeking a passionate multimedia content creator to spearhead our video production efforts on YouTube and other platforms. This role will involve creating engaging and informative video content that for example simplifies several privacy concepts and offers practical tips for protecting personal information. The ideal candidate will have experience in video production (but this is not strictly required) and a commitment to making complex topics accessible to a wide audience. | ||||
|  | ||||
| This is your chance to enter the tech & educational content creation space, without worrying about sponsors and advertisers diluting your message. We have no commercial interests to interfere with your content, and no agenda beyond simply providing the best privacy information out there. If you're excited about using the power of video to educate and inspire, we want to hear from you! | ||||
|  | ||||
| [Learn more and apply here :material-arrow-right-drop-circle:](https://privacyguides.org/en/about/jobs/content-creator/) | ||||
|  | ||||
| ## Journalist | ||||
|  | ||||
| We are also looking for a skilled journalist to join our team. This role will focus on producing in-depth articles for our blog that explore the latest trends in privacy and security, as well as the implications of emerging technologies. The ideal candidate will have a background in investigative journalism and a deep understanding of privacy issues. Your work will help inform our community and foster critical discussions about digital rights and responsibilities. | ||||
|  | ||||
| Other tasks will be to research new subjects to cover, perform interviews, and conduct product and service reviews for our recommendations. | ||||
|  | ||||
| [Learn more and apply here :material-arrow-right-drop-circle:](https://privacyguides.org/en/about/jobs/journalist/) | ||||
|  | ||||
| ## News Curation Internship | ||||
|  | ||||
| Finally, we are offering a paid internship position that will focus on staying up-to-date with the latest privacy and security news, interacting with our community, and providing overall support to our volunteers. This role will involve curating relevant articles, reports, and insights to keep our team informed and engaged with current events. This is an excellent opportunity for someone passionate about privacy issues and looking to gain hands-on experience in a non-profit environment. Ideal candidates will have strong research skills and a keen interest in digital rights. | ||||
|  | ||||
| [Learn more and apply here :material-arrow-right-drop-circle:](https://privacyguides.org/en/about/jobs/intern-news/) | ||||
|  | ||||
| ## Join us in making a difference | ||||
|  | ||||
| At Privacy Guides, we believe that everyone deserves the right to privacy and security in the digital world. By joining our team, you will play a vital role in educating the public and advocating for stronger privacy protections. If you’re ready to make a difference and are excited about one of these roles, we encourage you to apply! | ||||
							
								
								
									
										76
									
								
								blog/posts/linux-application-sandboxing.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,76 @@ | ||||
| --- | ||||
| date: | ||||
|     created: 2022-04-22 | ||||
| categories: | ||||
|     - Tutorials | ||||
| authors: | ||||
|     - contributors | ||||
| tags: | ||||
|     - Linux | ||||
|     - Security | ||||
| license: BY-SA | ||||
| description: We outline a few projects which aim to solve the poor sandboxing situation in Linux relative to operating systems like macOS and ChromeOS. | ||||
| schema_type: AnalysisNewsArticle | ||||
| --- | ||||
| # Sandboxing Applications on Desktop Linux | ||||
|  | ||||
| Some sandboxing solutions for desktop Linux distributions do exist, however they are not as strict as those found in macOS or ChromeOS. Applications installed from the package manager (`dnf`, `apt`, etc.) typically have **no** sandboxing or confinement whatsoever. Below are a few projects that aim to solve this problem:<!-- more --> | ||||
|  | ||||
| ## Flatpak | ||||
|  | ||||
| [Flatpak](https://flatpak.org) aims to be a universal package manager for Linux. One of its main functions is to provide a universal package format which can be used in most Linux distributions. It provides some [permission control](https://docs.flatpak.org/en/latest/sandbox-permissions.html).However, [it is known](https://madaidans-insecurities.github.io/linux.html#flatpak) that Flatpak sandboxing could be improved as particular Flatpaks often have greater permission than required. There does seem to be [some agreement](https://theevilskeleton.gitlab.io/2021/02/11/response-to-flatkill-org.html) that this is the case. | ||||
|  | ||||
| You can restrict applications further by issuing [Flatpak overrides](https://docs.flatpak.org/en/latest/flatpak-command-reference.html#flatpak-override). This can be done with the command-line or by using [Flatseal](https://flathub.org/apps/details/com.github.tchx84.Flatseal). Some sample overrides are provided by [rusty-snake](https://github.com/rusty-snake/kyst/tree/main/flatpak). | ||||
|  | ||||
| We generally recommend revoking access to: | ||||
|  | ||||
| - the Network (`share=network`) socket (internet access) | ||||
| - the PulseAudio socket (for both audio in and out), `device=all` (access to all devices including the camera) | ||||
| - `org.freedesktop.secrets` dbus (access to secrets stored on your keychain) for applications which do not need it | ||||
|  | ||||
| If an application works natively with Wayland (and not running through the [XWayland](https://wayland.freedesktop.org/xserver.html) compatibility layer), consider revoking its access to the X11 (`socket=x11`) and [Inter-process communications (IPC)](https://en.wikipedia.org/wiki/Unix_domain_socket) socket (`share=ipc`) as well. | ||||
|  | ||||
| We also recommend restricting broad filesystem permissions such as `filesystem=home` and `filesystem=host` which should be revoked and replaced with just the directories that the app needs to access. Some applications like [VLC](https://www.flathub.org/apps/details/org.videolan.VLC) implement the [Portals](https://docs.flatpak.org/en/latest/portal-api-reference.html) [API](https://en.wikipedia.org/wiki/API), which allows a file manager to pass files to the Flatpak application (e.g. VLC) without specific filesystem access privileges. VLC is only able to access the specific file that you want to open, rather than requiring privileges to particular locations. | ||||
|  | ||||
| Hard-coded access to some kernel interfaces like [`/sys`](https://en.wikipedia.org/wiki/Sysfs) and [`/proc`](https://en.wikipedia.org/wiki/Procfs#Linux) and weak [seccomp](https://en.wikipedia.org/wiki/Seccomp) filters unfortunately cannot be secured with Flatpak. | ||||
|  | ||||
| ## Firejail | ||||
|  | ||||
| [Firejail](https://firejail.wordpress.com/) is another method of sandboxing. As it is a large [setuid](https://en.wikipedia.org/wiki/Setuid) binary, it has a large attack surface which may assist in [privilege escalation](https://en.wikipedia.org/wiki/Privilege_escalation). | ||||
|  | ||||
| [This post from a Whonix security researcher](https://madaidans-insecurities.github.io/linux.html#firejail) provides additional details on how Firejail can worsen the security of your device. | ||||
|  | ||||
| ## Mandatory Access Control | ||||
|  | ||||
| [Mandatory access control](https://en.wikipedia.org/wiki/Mandatory_access_control) systems require policy files in order to force constraints on the system. | ||||
|  | ||||
| The two main control systems are [SELinux](https://en.wikipedia.org/wiki/Security-Enhanced_Linux) (used on Android and Fedora) and [AppArmor](https://en.wikipedia.org/wiki/AppArmor). | ||||
|  | ||||
| Fedora includes SELinux preconfigured with some policies that will confine [system daemons](https://en.wikipedia.org/wiki/Daemon_(computing)) (background processes). We don’t recommend disabling SELinux. | ||||
|  | ||||
| openSUSE gives the choice of AppArmor or SELinux during the installation process. We recommend sticking to the default for each variant (AppArmor for [Tumbleweed](https://get.opensuse.org/tumbleweed/) and SELinux for [MicroOS](https://microos.opensuse.org/)). openSUSE’s SELinux policies are derived from Fedora. | ||||
|  | ||||
| Arch and Arch-based operating systems often do not come with a mandatory access control system and that must be configured manually for either [AppArmor](https://wiki.archlinux.org/title/AppArmor) or [SELinux](https://wiki.archlinux.org/title/SELinux). | ||||
|  | ||||
| Linux desktops don't usually include individual app confinement rules, unlike Android which sandboxes every application installed. | ||||
|  | ||||
| ## Making your own policies/profiles | ||||
|  | ||||
| You can make your own AppArmor profiles, SELinux policies, Bubblewrap profiles, and [seccomp](https://en.wikipedia.org/wiki/Seccomp) blacklist to have better confinement of applications. This is an advanced and sometimes tedious task, so we won’t go into detail about how to do it here, but we do have a few projects that you could use as reference. | ||||
|  | ||||
| - Whonix’s [AppArmor Everything](https://github.com/Whonix/apparmor-profile-everything) | ||||
| - Krathalan’s [AppArmor profiles](https://github.com/krathalan/apparmor-profiles) | ||||
| - noatsecure’s [SELinux templates](https://github.com/noatsecure/hardhat-selinux-templates) | ||||
| - Seirdy’s [Bubblewrap scripts](https://sr.ht/~seirdy/bwrap-scripts) | ||||
|  | ||||
| ## Securing Linux containers | ||||
|  | ||||
| If you’re running a server, you may have heard of Linux Containers, Docker, or Podman which refer to a kind of [OS-level virtualization](https://en.wikipedia.org/wiki/OS-level_virtualization). Containers are more common in server and development environments where individual apps are built to operate independently. | ||||
|  | ||||
| [Docker](https://en.wikipedia.org/wiki/Docker_(software)) is one of the most common container solutions. It does not run a proper sandbox, and this means that there is a large kernel attack surface. The [daemon](https://en.wikipedia.org/wiki/Daemon_(computing)) controls everything and [typically](https://docs.docker.com/engine/security/rootless/#known-limitations) runs as root. If it crashes for some reason, all the containers will crash too. The [gVisor](https://en.wikipedia.org/wiki/GVisor) runtime which implements an application level kernel can help limit the number of [syscalls](https://en.wikipedia.org/wiki/System_call) an application can make and can help isolate it from the host’s [kernel](https://en.wikipedia.org/wiki/Kernel_(operating_system)). | ||||
|  | ||||
| Red Hat develops [Podman](https://docs.podman.io/en/latest/) and secures it with SELinux to [isolate](https://www.redhat.com/sysadmin/apparmor-selinux-isolation) containers from each other. One of the notable differences between Docker and Podman is that Docker requires [root](https://en.wikipedia.org/wiki/Superuser) while Podman can run with [rootless containers](https://developers.redhat.com/blog/2020/09/25/rootless-containers-with-podman-the-basics) that are also [daemonless](https://developers.redhat.com/blog/2018/08/29/intro-to-podman), meaning if one crashes they don’t all come down. | ||||
|  | ||||
| Another option is [Kata containers](https://katacontainers.io/), where virtual machines masquerade as containers. Each Kata container has its own Linux kernel and is isolated from the host. | ||||
|  | ||||
| The above container technologies can be useful if you want to run certain web app software on your local network, such as [Vaultwarden](https://github.com/dani-garcia/vaultwarden) or images provided by [LinuxServer.io](https://www.linuxserver.io), to increase privacy by decreasing dependence on various web services. A guide on [hardening Docker and OCI](https://wonderfall.dev/docker-hardening) has been written by the author "Wonderfall." | ||||
							
								
								
									
										140
									
								
								blog/posts/linux-system-hardening.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,140 @@ | ||||
| --- | ||||
| date: | ||||
|     created: 2022-04-22 | ||||
| categories: | ||||
|     - Tutorials | ||||
| authors: | ||||
|     - contributors | ||||
| tags: | ||||
|     - Linux | ||||
|     - Security | ||||
| license: BY-SA | ||||
| robots: nofollow, max-snippet:-1, max-image-preview:large | ||||
| description: There are a number of procedures you can follow to make your Linux desktop system more secure, some more advanced than others. We cover some general techniques here. | ||||
| schema_type: AnalysisNewsArticle | ||||
| --- | ||||
| # Hardening Your Desktop Linux System's Security | ||||
|  | ||||
| There are a number of procedures you can follow to make your Linux desktop system more secure, some more advanced than others. We cover some general techniques here.<!-- more --> | ||||
|  | ||||
| ## Firewalls | ||||
|  | ||||
| A [firewall](https://en.wikipedia.org/wiki/Firewall_(computing)) may be used to secure connections to your system. If you’re on a public network, the necessity of this may be greater than if you’re on a local trusted network that you control. We would generally recommend that you block incoming connections only, unless you’re using an application firewall such as [OpenSnitch](https://github.com/evilsocket/opensnitch) or [Portmaster](https://safing.io/portmaster/). | ||||
|  | ||||
| Red Hat distributions (such as Fedora) are typically configured through [firewalld](https://en.wikipedia.org/wiki/Firewalld). Red Hat has plenty of [documentation](https://access.redhat.com/documentation/en-us/red_hat_enterprise_linux/8/html/configuring_and_managing_networking/using-and-configuring-firewalld_configuring-and-managing-networking) regarding this topic. There is also the [Uncomplicated Firewall](https://en.wikipedia.org/wiki/Uncomplicated_Firewall) which can be used as an alternative. | ||||
|  | ||||
| You could also set your default firewall zone to drop packets. If you're on a Redhat based distribution, such as Fedora this can be done with the following commands: | ||||
|  | ||||
| !!! Example | ||||
|  | ||||
|     ```bash | ||||
|     firewall-cmd --set-default-zone=drop; | ||||
|     firewall-cmd --add-protocol=ipv6-icmp --permanent; | ||||
|     firewall-cmd --add-service=dhcpv6-client --permanent; | ||||
|     ``` | ||||
|  | ||||
| All these firewalls use the [Netfilter](https://en.wikipedia.org/wiki/Netfilter) framework and therefore cannot protect against malicious programs running on the system. A malicious program could insert its own rules. | ||||
|  | ||||
| If you are using Flatpak packages, you can revoke their network socket access using Flatseal and prevent those applications from accessing your network. This permission is not bypassable. | ||||
|  | ||||
| If you are using non-classic [Snap](https://en.wikipedia.org/wiki/Snap_(package_manager)) packages on a system with proper snap confinement support (with both AppArmor and [cgroups](https://en.wikipedia.org/wiki/Cgroups) v1 present), you can use the Snap Store to revoke network permission as well. This is also not bypassable. | ||||
|  | ||||
| ## Kernel hardening | ||||
|  | ||||
| Kernel hardening options such as configuring [sysctl](https://en.wikipedia.org/wiki/Sysctl#Linux) keys and [kernel command-line parameters](https://www.kernel.org/doc/html/latest/admin-guide/kernel-parameters.html) can help harden your system. We suggest looking at the following [sysctl settings](https://madaidans-insecurities.github.io/guides/linux-hardening.html#sysctl) and [boot parameters](https://madaidans-insecurities.github.io/guides/linux-hardening.html#boot-parameters). | ||||
|  | ||||
| We **strongly** recommend that you learn what these options do before applying them. There are also some methods of [kernel attack surface reduction](https://madaidans-insecurities.github.io/guides/linux-hardening.html#kernel-attack-surface-reduction) and [access restrictions to sysfs](https://madaidans-insecurities.github.io/guides/linux-hardening.html#restricting-sysfs) that can further improve security. | ||||
|  | ||||
| !!! Note | ||||
|     Unprivileged [user namespaces](https://madaidans-insecurities.github.io/linux.html#kernel) can be disabled, due to it being responsible for various privileged escalation vulnerabilities. Some software such as Docker, Podman, and LXC require unprivileged user namespaces to function. If you use these tools you should not disable `kernel.unprivileged_userns_clone`. | ||||
|  | ||||
|     Disabling access to `/sys` without a proper whitelist will lead to various applications breaking. This will unfortunately be an extremely tedious process for most users. Kicksecure, and by extension, Whonix, has an experimental [hide hardware info service](https://github.com/Kicksecure/security-misc/blob/master/lib/systemd/system/hide-hardware-info.service) which does just this. From our testing, these work perfectly fine on minimal Kicksecure installations and both Qubes-Whonix Workstation and Gateway. If you are using Kicksecure or Whonix, we recommend that you follow the [Kicksecure Wiki](https://www.kicksecure.com/wiki/Security-misc) to enable hide hardware info service. | ||||
|  | ||||
| ## Linux-Hardened | ||||
|  | ||||
| Some distributions like Arch Linux have the [linux-hardened](https://github.com/anthraxx/linux-hardened), kernel package. It includes [hardening patches](https://wiki.archlinux.org/title/security#Kernel_hardening) and more security-conscious defaults. Linux-Hardened has `kernel.unprivileged_userns_clone=0` disabled by default. See the [note above](#kernel-hardening) about how this might impact you. | ||||
|  | ||||
| ## Linux Kernel Runtime Guard (LKRG) | ||||
|  | ||||
| LKRG is a kernel module that performs runtime integrity check on the kernel to help detect exploits against the kernel. LKRG works in a *post*-detect fashion, attempting to respond to unauthorized modifications to the running Linux kernel. While it is [bypassable by design](https://lkrg.org/), it does stop off-the-shelf malware that does not specifically target LKRG itself. This may make exploits harder to develop and execute on vulnerable systems. | ||||
|  | ||||
| If you can get LKRG and maintain module updates, it provides a worthwhile improvement to security. Debian based distributions can get the LKRG DKMS package from KickSecure's secure repository and the [KickSecure documentation](https://www.kicksecure.com/wiki/Linux_Kernel_Runtime_Guard_LKRG) has instructions. | ||||
|  | ||||
| On Fedora, [fepitre](https://github.com/fepitre), a QubesOS developer has a [COPR repository](https://copr.fedorainfracloud.org/coprs/fepitre/lkrg/) where you can install it. Arch based systems can obtain the LKRG DKMS package via an [AUR package](https://aur.archlinux.org/packages/lkrg-dkms). | ||||
|  | ||||
| ## GRSecurity | ||||
|  | ||||
| GRSecurity is a set of kernel patches that attempt to improve security of the Linux kernel. It requires [payment to access](https://grsecurity.net/purchase) the code and is worth using if you have a subscription. | ||||
|  | ||||
| ## Simultaneous multithreading (SMT) | ||||
|  | ||||
| [SMT](https://en.wikipedia.org/wiki/Simultaneous_multithreading) has been the cause of numerous hardware vulnerabilities, and subsequent patches for those vulnerabilities often come with performance penalties that negate most of the performance gain given by SMT. If you followed the “kernel hardening” section above, some kernel parameters already disable SMT. If the option is available to you, we recommend that you disable it in your firmware as well. | ||||
|  | ||||
| ## Hardened memory allocator | ||||
|  | ||||
| The [hardened memory allocator](https://github.com/GrapheneOS/hardened_malloc) from [GrapheneOS](https://grapheneos.org) can also be used on general Linux distributions. It is available as an [AUR package](https://wiki.archlinux.org/title/Security#Hardened_malloc) on Arch based distributions, and (though not enabled by default) on Whonix and Kicksecure. | ||||
|  | ||||
| If you are using Whonix, Kicksecure or the AUR package, consider setting up `LD_PRELOAD` as described in the [Kicksecure Documentation](https://www.kicksecure.com/wiki/Hardened_Malloc) or [Arch Wiki](https://wiki.archlinux.org/title/Security#Hardened_malloc). | ||||
|  | ||||
| ## Umask | ||||
|  | ||||
| If you are not using openSUSE, consider changing the default [umask](https://en.wikipedia.org/wiki/Umask) for both regular user accounts and root to 077. Changing umask to 077 can break snapper on openSUSE and is **not** recommended. | ||||
|  | ||||
| ## Mountpoint hardening | ||||
|  | ||||
| Consider adding the [following options](https://man7.org/linux/man-pages/man8/mount.8.html) `nodev`, `noexec`, and `nosuid` to [mountpoints](https://en.wikipedia.org/wiki/Mount_(computing)) which do not need them. Typically, these could be applied to `/boot`, `/boot/efi`, and `/var`. | ||||
|  | ||||
| These flags could also be applied to `/home` and `/root` as well, however, `noexec` will prevent applications from working that require binary execution in those locations. This includes products such as Flatpak and Snap. | ||||
|  | ||||
| If you use [Toolbox](https://docs.fedoraproject.org/en-US/fedora-silverblue/toolbox/), `/var/log/journal` must not have any of those options. If you are on Arch Linux, do not apply `noexec` to `/var/tmp`. | ||||
|  | ||||
| ## Disabling SUID | ||||
|  | ||||
| SUID allows a user to execute an application as the owner of that application, which in many cases, would be the `root` user. Vulnerable SUID executables could lead to privilege escalation vulnerabilities. | ||||
|  | ||||
| It is desirable to remove SUID from as many binaries as possible; however, this takes substantial effort and trial and error on the user's part, as some applications require SUID to function. | ||||
|  | ||||
| Kicksecure, and by extension, Whonix has an experimental [permission hardening service](https://github.com/Kicksecure/security-misc/blob/master/lib/systemd/system/permission-hardening.service) and [application whitelist](https://github.com/Kicksecure/security-misc/tree/master/etc/permission-hardening.d) to automate SUID removal from most binaries and libraries on the system. From our testing, these work perfectly fine on a minimal Kicksecure installation and both Qubes-Whonix Workstation and Gateway. | ||||
|  | ||||
| If you are using Kicksecure or Whonix, we recommend that you follow the [Kicksecure Wiki](https://www.kicksecure.com/wiki/SUID_Disabler_and_Permission_Hardener) to enable the permission hardener. | ||||
|  | ||||
| Users of other distributions can adapt the permission hardener to their own system based on the source code linked above. | ||||
|  | ||||
| ## Secure Time Synchronization | ||||
|  | ||||
| Most Linux distributions by default (especially Arch based distributions with `systemd-timesyncd`) use un-encrypted NTP for time synchronization. Securing NTP can be achieved by [configuring NTS with chronyd](https://fedoramagazine.org/secure-ntp-with-nts/) or by using [swdate](https://github.com/Kicksecure/sdwdate) on Debian based distributions. | ||||
|  | ||||
| ## Linux Pluggable Authentication Modules (PAM) | ||||
|  | ||||
| The security of [PAM](https://en.wikipedia.org/wiki/Linux_PAM) can be [hardened](https://madaidans-insecurities.github.io/guides/linux-hardening.html#pam) to allow secure authentication to your system. | ||||
|  | ||||
| On Red Hat distributions you can use [`authselect`](https://access.redhat.com/documentation/en-us/red_hat_enterprise_linux/8/html/configuring_authentication_and_authorization_in_rhel/configuring-user-authentication-using-authselect_configuring-authentication-and-authorization-in-rhel) to configure this e.g.: | ||||
|  | ||||
| ```bash | ||||
| sudo authselect select <profile_id, default: sssd> with-faillock without-nullok with-pamaccess | ||||
| ``` | ||||
|  | ||||
| On systems where [`pam_faillock`](https://man7.org/linux/man-pages/man8/pam_tally.8.html) is not available, consider using [`pam_tally2`](https://man7.org/linux/man-pages/man8/pam_tally.8.html) instead. | ||||
|  | ||||
| ## USB port protection | ||||
|  | ||||
| To better protect your [USB](https://en.wikipedia.org/wiki/USB) ports from attacks such as [BadUSB](https://en.wikipedia.org/wiki/BadUSB), we recommend [USBGuard](https://github.com/USBGuard/usbguard). USBGuard has [documentation](https://github.com/USBGuard/usbguard#documentation) as does the [Arch Wiki](https://wiki.archlinux.org/title/USBGuard). | ||||
|  | ||||
| Another alternative option if you’re using the [linux-hardened](#linux-hardened) is the [`deny_new_usb`](https://github.com/GrapheneOS/linux-hardened/commit/96dc427ab60d28129b36362e1577b6673b0ba5c4) sysctl. See [Preventing USB Attacks with `linux-hardened`](https://blog.lizzie.io/preventing-usb-attacks-with-linux-hardened.html). | ||||
|  | ||||
| ## Secure Boot | ||||
|  | ||||
| [Secure Boot](https://en.wikipedia.org/wiki/Unified_Extensible_Firmware_Interface#Secure_Boot) can be used to secure the boot process by preventing the loading of [unsigned](https://en.wikipedia.org/wiki/Public-key_cryptography) [UEFI](https://en.wikipedia.org/wiki/Unified_Extensible_Firmware_Interface) drivers or [boot loaders](https://en.wikipedia.org/wiki/Bootloader). | ||||
|  | ||||
| One of the problems with Secure Boot, particularly on Linux is, that only the [chainloader](https://en.wikipedia.org/wiki/Chain_loading#Chain_loading_in_boot_manager_programs) (shim), the [boot loader](https://en.wikipedia.org/wiki/Bootloader) (GRUB), and the [kernel](https://en.wikipedia.org/wiki/Kernel_(operating_system)) are verified and that's where verification stops. The [initramfs](https://en.wikipedia.org/wiki/Initial_ramdisk) is often left unverified, unencrypted, and open up the window for an [evil maid](https://en.wikipedia.org/wiki/Evil_maid_attack) attack. The firmware on most devices is also configured to trust Microsoft's keys for Windows and its partners, leading to a large attacks surface. | ||||
|  | ||||
| To eliminate the need to trust Microsoft's keys, follow the "Using your own keys" section on the [Arch Wiki](https://wiki.archlinux.org/title/Unified_Extensible_Firmware_Interface/Secure_Boot). The important thing that needs to be done here is to replace the OEM's key with your own Platform Key. | ||||
|  | ||||
| - If you enroll your own keys as described above, and your distribution supports Secure Boot by default, you can add your distribution's EFI Key into the list of trusted keys (db keys). It can then be enrolled into the firmware. Then, you should move all of your keys off your local storage device. | ||||
| - If you enroll your own keys as described above, and your distribution does **not** support Secure Boot out of the box (like Arch Linux), you have to leave the keys on the disk and setup automatic signing of the [kernel](https://wiki.archlinux.org/title/Unified_Extensible_Firmware_Interface/Secure_Boot#Signing_the_kernel_with_a_pacman_hook) and bootloader. If you are using Grub, you can install it with the `--no-shim-lock` option and remove the need for the chainloader. | ||||
|  | ||||
| The second option is to creating an [EFI Boot Stub](https://wiki.archlinux.org/title/Unified_kernel_image) that contains the [kernel](https://en.wikipedia.org/wiki/Kernel_(operating_system)), [initramfs](https://en.wikipedia.org/wiki/Initial_ramdisk), and [microcode](https://en.wikipedia.org/wiki/Microcode). This EFI stub can then be signed. If you use [dracut](https://en.wikipedia.org/wiki/Dracut_(software)) this can easily be done with the [`--uefi-stub` switch](https://man7.org/linux/man-pages/man8/dracut.8.html) or the [`uefi_stub` config](https://www.man7.org/linux/man-pages/man5/dracut.conf.5.html) option. This option also requires you to leave the keys on the disk to setup automatic signing, which weakens the security model. | ||||
|  | ||||
| After setting up Secure Boot it is crucial that you set a “firmware password” (also called a “supervisor password”, “BIOS password” or “UEFI password”), otherwise an adversary can simply disable Secure Boot. | ||||
|  | ||||
| These recommendations can make you a little more resistant to [evil maid](https://en.wikipedia.org/wiki/Evil_maid_attack) attacks, but they not good as a proper verified boot process such as that found on [Android](https://source.android.com/security/verifiedboot), [ChromeOS](https://www.chromium.org/chromium-os/chromiumos-design-docs/security-overview/#verified-boot), [macOS](https://support.apple.com/en-us/HT208198), or [Windows](https://docs.microsoft.com/en-us/windows/security/information-protection/secure-the-windows-10-boot-process). | ||||
							
								
								
									
										94
									
								
								blog/posts/macos-ventura-privacy-security-updates.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,94 @@ | ||||
| --- | ||||
| date: | ||||
|     created: 2022-10-27 | ||||
| categories: | ||||
|     - News | ||||
| authors: | ||||
|     - jonah | ||||
| tags: | ||||
|     - macOS | ||||
|     - Security | ||||
| links: | ||||
|     - posts/ios-configuration-guide.md | ||||
| license: BY-SA | ||||
| description: We cover the improvements macOS Ventura will bring to Apple users when it comes to personal privacy and security. | ||||
| schema_type: NewsArticle | ||||
| --- | ||||
| # New Privacy and Security Features in macOS 13 Ventura | ||||
|  | ||||
| macOS Ventura was released this week, and the Apple users among us may be interested in the improvements it brings to your personal privacy and security. We always recommend running the most up-to-date version of your operating system available. Updates add privacy and security improvements all the time—and macOS Ventura is no exception.<!-- more --> Some notable new additions to the macOS privacy ecosystem include: | ||||
|  | ||||
| - Lockdown Mode | ||||
| - Rapid Security Responses | ||||
| - Passkeys | ||||
|  | ||||
| Let's venture in and see what these updates will mean for you. | ||||
|  | ||||
| ## Lockdown Mode | ||||
|  | ||||
| Apple's headline security feature for macOS and iOS this year was **Lockdown Mode**, a setting which allows you to enable much stricter security protections on your device. Designed for the rare few who are actively targeted by cyberattacks, Lockdown Mode still received widespread attention in the privacy and security space as an important attack surface reduction tool. | ||||
|  | ||||
| Enabling Lockdown Mode can be done easily in the **System Settings** app: | ||||
|  | ||||
| 1. Click **Privacy & Security** in the sidebar. | ||||
| 2. Scroll down to **Lockdown Mode** and click **Turn On**. | ||||
| 3. Click **Turn On & Restart** to restart your device in Lockdown Mode. | ||||
|  | ||||
| Lockdown Mode needs to be enabled separately on each device. Lockdown Mode [changes your device's behavior](https://support.apple.com/en-us/HT212650) significantly in a number of ways. Its worth trying for yourself to see if it impacts your everyday usage. There is little downside to enabling it as its impact to most features is relatively minor in day-to-day use. | ||||
|  | ||||
| ### Safari | ||||
|  | ||||
| Enabling Lockdown Mode disables a number of "complex web technologies". These can impact your device's browsing performance and battery efficiency, in some cases to a significant degree. The changes to Safari include: | ||||
|  | ||||
| - JavaScript's Just-in-Time (JIT) compilation features are disabled. JIT allows JavaScript code to be compiled on the fly during its execution. Disabling JIT shows performance decreases by up to 95% in some browser benchmarks, though this difference is difficult to notice in everyday browsing. Unfortunately, the added performance and complexity of JIT in JavaScript comes with a [significant security cost](https://microsoftedge.github.io/edgevr/posts/Super-Duper-Secure-Mode/). An analysis [conducted](https://docs.google.com/spreadsheets/d/1FslzTx4b7sKZK4BR-DpO45JZNB1QZF9wuijK3OxBwr0/edit#gid=0) by Mozilla indicates that over half of Chrome exploits "in the wild" abused a JIT bug, so disabling JIT can roughly cut your attack surface in half. | ||||
| - [WebAssembly](https://en.wikipedia.org/wiki/WebAssembly) (WASM) support is also disabled. WASM was created to allow for high-performance applications on web pages; however, it can be used to fingerprint browsers to track people across websites and apps. | ||||
| - JPEG 2000 support is disabled. Safari is the only modern browser to [support](https://caniuse.com/jpeg2000) the JPEG 2000 image format, which makes its support an easy way to identify Safari users. | ||||
| - PDF previews are disabled. The PDF format has historically been subject to a number of exploits; this change means that PDF files will be downloaded and have to be opened in a dedicated PDF previewing app instead. | ||||
|  | ||||
| Other technologies that were [disabled](https://blog.alexi.sh/posts/2022/07/lockdown-jsc/) include WebGL, MathML, Gamepad API, Web Audio API, RTCDataChannel, and SVG Fonts. Additionally, many other external web fonts are disabled, limiting websites to only the fonts pre-installed on the device. This notably breaks a lot of icons on various websites, which are often replaced by an empty square. | ||||
|  | ||||
| Luckily, Lockdown Mode can be disabled on a per-site basis on Safari, so none of these issues should prevent you from enabling Lockdown Mode on your device. If you encounter a trusted website which breaks with Lockdown Mode enabled, you can easily add an exception for that website while keeping the rest of Lockdown Mode's protections intact. | ||||
|  | ||||
| ### Apple Services | ||||
|  | ||||
| Lockdown Mode also changes the way a number of different Apple services are used on your device. | ||||
|  | ||||
| - **Messages**: Most message attachments are blocked, besides certain image, video, and audio attachments. This includes most iMessage "apps" such as in-conversation games. Link previews are also disabled. | ||||
| - **FaceTime**: Incoming calls are blocked, unless you have previously called that person or contact. This is likely in response to past FaceTime bugs, such as the [exploit in 2019](https://9to5mac.com/2019/01/28/facetime-bug-hear-audio/) which allowed an attacker to listen in on your microphone before you picked up the call. | ||||
| - **Photos**: The new Shared Albums functionality in iCloud Photos is blocked, and invitations are automatically rejected. Shared Albums do still work on any devices without Lockdown Mode enabled. | ||||
|  | ||||
| In addition to these, other Apple services like **Home** will reject incoming invitations unless you have previously interacted with the sender. | ||||
|  | ||||
| ### Device Changes | ||||
|  | ||||
| Some other device functionality is limited with Lockdown Mode enabled as well. If you have a Mac with Apple Silicon, connected devices or accessories are not allowed to connect unless your Mac is unlocked and explicit approval of the device is given. Configuration profiles can no longer be installed either, and the ability to enroll in a Mobile Device Management (MDM) system is disabled. These are enterprise management features, which are occasionally abused to control or monitor devices. | ||||
|  | ||||
| ## Passkeys | ||||
|  | ||||
| **Passkeys** are likely to be the most impactful new feature for the everyday person's security practices. Passkeys are a cross-platform standard supported by Google, Apple, and Microsoft. Based on the FIDO2 standard, passkeys are the first real effort to replace passwords as your primary mode of authentication. | ||||
|  | ||||
| Using a passkey stored on your phone is supported by most browsers in macOS, but only Safari currently allows you to use a passkey stored on your Mac. Passkeys generated on your iPhone or Mac are stored in iCloud Keychain, which is end-to-end encrypted with your phone or computer's lock screen password. In Safari, passkeys are replacing the single-device WebAuthn registration, which allowed you to use your computer as a hardware key with Touch ID. | ||||
|  | ||||
| The benefits of passkeys are fairly limited at the moment, until more services support the standard for primary or multi-factor authentication. | ||||
|  | ||||
| ## Rapid Security Responses | ||||
|  | ||||
| Alongside iOS 16, Apple is introducing **Rapid Security Responses** (RSR) to macOS Ventura. RSR allows Apple to ship small security fixes on the fly much faster than before. | ||||
|  | ||||
| Previously, releasing even a small security patch meant Apple had to release a huge multi-gigabyte update package. This was required to preserve the system's cryptographic integrity, following changes to how the system volume is handled in macOS Big Sur. With RSR, updates are much smaller, so patches can be downloaded much faster and applied more reliably. | ||||
|  | ||||
| RSR patches are applied immediately. However, [they are tied](https://support.apple.com/guide/deployment/whats-new-dep950aed53e/1/web/1.0) to the macOS minor version they are released with, meaning you need to be on the latest available macOS update to receive them: they are not a replacement for regular updates. | ||||
|  | ||||
| What [remains to be seen](https://eclecticlight.co/2022/09/22/apple-can-patch-ventura-on-the-fly-rsr-is-coming/) is which security patches will be released via RSR as opposed to standard security updates. More severe bugs, including Mach zone memory leaks and bugs which could cause kernel panics, are still likely to require a formal macOS update rather than a quick patch. | ||||
|  | ||||
| ## Gatekeeper Changes | ||||
|  | ||||
| **Gatekeeper** is Apple's primary approach to handling malware on macOS, which has historically operated as a "scan at launch" feature for newly downloaded apps. In macOS Ventura, Gatekeeper has been updated to run signature and notarization checks upon every launch of an application, as opposed to just the first launch. This should improve its malware scanning capabilities, but could potentially [cause problems](https://eclecticlight.co/2022/09/24/why-some-apps-wont-run-in-ventura-and-how-to-fix-it/) with apps which update themselves. This practice is common with apps distributed outside the App Store, and could lead to discrepancies between the app's code signature and actual content. | ||||
|  | ||||
| ## A Bug with Malware Scanners and Monitoring Tools | ||||
|  | ||||
| WIRED [reported](https://www.wired.com/story/apple-macos-ventura-bug-security-tools/) that a bug in the initial release of macOS Ventura cuts off third-party security products like [BlockBlock](https://objective-see.org/products/blockblock.html) from Objective-See from the access they need to perform system scans. There is a workaround to fix this access, so if you use tools like these you should manually check your security app to make sure it is working as intended. Apple should fix this problem in the next system update. | ||||
|  | ||||
| ## Final Thoughts | ||||
|  | ||||
| If you are a Mac user, macOS Ventura brings a lot of new security and privacy features to the table. We recommend upgrading to macOS Ventura as soon as possible (I already have). We'll continue to keep an eye on how security features like these are used and improved in the future, on Apple platforms and beyond. | ||||
							
								
								
									
										31
									
								
								blog/posts/merch-announcement.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,31 @@ | ||||
| --- | ||||
| date: | ||||
|     created: 2023-05-31 | ||||
| categories: | ||||
|     - Announcements | ||||
| authors: | ||||
|     - freddy | ||||
|     - niek-de-wilde | ||||
| tags: | ||||
|     - Privacy Guides | ||||
| license: BY-SA | ||||
| description: Privacy Guides has partnered with HELLOTUX to create what we think are the finest garments in the land. | ||||
| schema_type: BackgroundNewsArticle | ||||
| --- | ||||
| # Privacy Guides Now Has Merchandise | ||||
|  | ||||
| Yes, you read the title correctly: we have merch now. Privacy Guides has partnered with [HELLOTUX](https://www.hellotux.com/privacyguides) to create what we think are the finest garments in the land.<!-- more --> | ||||
|  | ||||
| It would be ironic to sell our products on a site riddled with ads and trackers. So we weren't going to. This decision ruled out loads of providers, as our privacy-focused values and their Google Analytics just didn't quite align. Privacy Guides has a global audience, so worldwide shipping was a must. And we didn't want to be peddling tacky cheaply printed t-shirts either. This narrowed down our options considerably. | ||||
|  | ||||
| Then we stumbled across HELLOTUX. | ||||
|  | ||||
| HELLOTUX is a family business who have been making high quality merchandise for open source projects since 2002. Their site is tracker free, and isn't littered with irritating adverts. They seemed, pardon the pun, the perfect fit. | ||||
|  | ||||
| We're excited to launch a range of dashing t-shirts and Polo shirts, along with our very own hoodies and jackets. Check them out at [`www.hellotux.com/privacyguides`](https://www.hellotux.com/privacyguides). | ||||
|  | ||||
| Buying our merch is a great way to support us financially. We get between three to five dollars per garment, depending on the product. Privacy Guides is a non-profit, socially motivated website so all the money we receive will be put towards improving our site and community. Our finances can be viewed publicly via the [Open Collective](https://opencollective.com/privacyguides). | ||||
|  | ||||
| A fun fact about HELLOTUX is that they make everything with Linux: the embroidery, the website, the customer service - the whole shebang. They also offer a money back guarantee. If you're not happy with your order, just send it back within three months, and they will sort you out with a replacement or refund. | ||||
|  | ||||
| So go ahead: bag yourself some Privacy Guides swag today! | ||||
							
								
								
									
										38
									
								
								blog/posts/move-fast-and-break-things.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,38 @@ | ||||
| --- | ||||
| date: | ||||
|     created: 2022-04-04 | ||||
| categories: | ||||
|     - Opinion | ||||
| authors: | ||||
|     - freddy | ||||
| links: | ||||
|     - posts/virtual-insanity.md | ||||
| tags: | ||||
|     - Facebook | ||||
| license: BY-SA | ||||
| description: If someone has to tell you that they care about your privacy, they probably don’t. | ||||
| schema_type: OpinionNewsArticle | ||||
| --- | ||||
| # Move Fast and Break Things | ||||
|  | ||||
| Mark Zuckerberg does not look comfortable on stage. Yet, there he was proclaiming that “the future is private”. If someone has to tell you that they care about your privacy, they probably don’t.<!-- more --> | ||||
|  | ||||
| For someone trying not to appear like a cartoon villain, Zuckerberg doesn’t do a great job. He gives the impression of some strange cyborg algorithmically attempting to impersonate human life. His movements are not quite robotic, but he lacks the charisma you might expect from one of the most powerful people on the planet. A *New Yorker* [profile](https://www.newyorker.com/magazine/2018/09/17/can-mark-zuckerberg-fix-facebook-before-it-breaks-democracy) of him revealed that he had an affinity for Emperor Augustus, an ancient Roman tyrant. ‘Through a really harsh approach, [Augustus] established two hundred years of world peace,’ he said. | ||||
|  | ||||
| It’s the first part of that sentence that is worrying. | ||||
|  | ||||
| Is this what Zuckerberg sees himself as: a modern-day emperor hellbent on using any means he can to gain world peace? Probably not, but it would have been reassuring if he just told us he liked doing Sudoku and dad-dancing with his daughter (interestingly named August). | ||||
|  | ||||
| The Zuck once [joked](https://www.esquire.com/uk/latest-news/a19490586/mark-zuckerberg-called-people-who-handed-over-their-data-dumb-f/) to a friend that he could get them ‘info’ about anyone in Harvard. He had email addresses, pictures, real addresses: the lot. When the friend asked how, this was his riposte: ‘People just submitted it. I don’t know why. They trust me. Dumb f*cks.’ We now live in a reality where Zuckerberg can get ‘info’ about almost anyone in the world. | ||||
|  | ||||
| Like a depraved tabloid journalist fishing through a minor celebrity’s trash, Facebook collects everything it can about its users. Even if it means sifting through garbage, they want that data. But Facebook is not technically in the data business. It is in what author and professor Carissa Véliz [terms](https://aeon.co/essays/privacy-matters-because-it-empowers-us-all) ‘the business of power’ – which sounds rather more sinister than flogging off mildly irritating adverts. | ||||
|  | ||||
| Véliz argues that privacy is a form of power. It is the power to influence you, show you adverts and predict your behaviour. In this sense, personal data is being used to make us do things we otherwise would not do: to buy a certain product or to vote a certain way. Filmmaker Laura Poitras [described](https://www.washingtonpost.com/news/the-switch/wp/2014/10/23/snowden-filmmaker-laura-poitras-facebook-is-a-gift-to-intelligence-agencies/) Facebook as ‘a gift to intelligence agencies’. It allows governments to arrest people planning to participate in protests before they have even begun. | ||||
|  | ||||
| The social media giant is tip-toeing ever closer into our personal lives. When Facebook encountered competition it just bought it, adding Instagram and WhatsApp to its roster. The company even tried to make its own cryptocurrency so that one day the Facebook would control all our purchases too. Earlier this year, the project was [killed](https://www.ft.com/content/a88fb591-72d5-4b6b-bb5d-223adfb893f3) by regulators. It is worth noting that when Zuckerberg purchased WhatsApp and Instagram, they had no revenue. Author Tim Wu notes in his book *The Attention Merchants* that Facebook is ‘a business with an exceedingly low ratio of invention to success’. Perhaps that is a part of Zuck’s genius. | ||||
|  | ||||
| ‘Move fast and break things’ was the old company motto. When there were a few too many scandals, they moved fast and [rebranded](https://www.privacyguides.org/blog/2021/11/01/virtual-insanity) to Meta. No one expected online privacy to be the ‘thing’ they broke. | ||||
|  | ||||
| Before it became a global behemoth, Facebook started out as a dorm-room project. Zuckerberg sat at his keyboard after a few drinks and built it mainly because he could. It now has nearly three billion users. In the same way, Facebook [conducted](https://www.theguardian.com/technology/2014/jul/02/facebook-apologises-psychological-experiments-on-users) social experiments seemingly just for fun. Why he did it doesn’t really matter. As John Lanchester [put it](https://www.lrb.co.uk/the-paper/v39/n16/john-lanchester/you-are-the-product): he simply did it *because*. | ||||
|  | ||||
| It is unfair to say that Zuckerberg does not care about privacy – he does. That’s why he [spared](https://www.theguardian.com/technology/2013/oct/11/mark-zuckerberg-facebook-neighbouring-houses) no expense buying the houses that surrounded his home. Zuckerberg knows the power of privacy, which is painfully ironic given he has built his career on exploiting it. For Zuckerberg, at least, the future is private. It’s the rest of us that should be worried. | ||||
							
								
								
									
										89
									
								
								blog/posts/mozilla-disappoints-us-yet-again-2.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,89 @@ | ||||
| --- | ||||
| date: | ||||
|     created: 2024-07-14 | ||||
| categories: | ||||
|     - News | ||||
| authors: | ||||
|     - jonah | ||||
| tags: | ||||
|     - Firefox | ||||
|     - Mozilla | ||||
| description: "'No shady privacy policies or back doors for advertisers' proclaims the Firefox homepage, but that's no longer true in Firefox 128." | ||||
| schema_type: AnalysisNewsArticle | ||||
| --- | ||||
|  | ||||
| # "Privacy-Preserving" Attribution: Mozilla Disappoints Us Yet Again | ||||
|  | ||||
|  | ||||
|  | ||||
| **"No shady privacy policies or back doors for advertisers" proclaims the Firefox homepage, but that's no longer true in Firefox 128.** | ||||
|  | ||||
| Less than a month after [acquiring the AdTech company Anonym](https://discuss.privacyguides.net/t/mozilla-acquires-anonym-raising-the-bar-for-privacy-preserving-digital-advertising/18936), Mozilla has added special software co-authored by Meta and built for the advertising industry directly to the latest release of Firefox, in an experimental trial you have to opt out of manually. This "Privacy-Preserving Attribution" (PPA) API adds another tool to the arsenal of tracking features that advertisers can use, which is thwarted by traditional content blocking extensions.<!-- more --> | ||||
|  | ||||
| It seems that 6 years after the [Mr. Robot extension debacle](https://www.theverge.com/2017/12/16/16784628/mozilla-mr-robot-arg-plugin-firefox-looking-glass), Mozilla still hasn't learned their lesson about sneaking unwanted advertising and features onto our computers. | ||||
|  | ||||
| We already know from Google's [Privacy Sandbox](https://www.eff.org/deeplinks/2019/08/dont-play-googles-privacy-sandbox-1) that simply adding "privacy" to the name of your feature does not make it private. While Mozilla claims that the "Privacy-Preserving" attribution aims to provide a more privacy-friendly alternative to ad tracking, there are a plethora of issues with this new (anti-)feature that are worth examining: | ||||
|  | ||||
| ## Misaligned Incentives | ||||
|  | ||||
| Mozilla's decision to implement PPA in Firefox highlights a growing trend among user agents (browsers) to grant preferential treatment to the advertising industry over all other businesses. | ||||
|  | ||||
| **All** websites on the internet—including ad networks!—are **guests** on our computers, and the content they provide are merely suggestions for a user agent to interpret and show us how it chooses. This has always been a fundamental truth of how the internet works, and enables many great things: from highly-accessible text-based web browsers to the ability to [block trackers](https://www.privacyguides.org/en/browser-extensions/) and other unwanted bloat on the websites you visit. By baking in software that's tailor-made for the advertising industry, Mozilla is wrongly asserting that the advertising industry has a legitimate interest in collecting your data and tracking you across the internet over all other parties, including over your own interests. | ||||
|  | ||||
| The advertising industry and [Google](https://discuss.privacyguides.net/t/ublock-origin-lite/15329/11) in particular have been trying their hardest to reverse this dynamic, to turn browsers into a locked-down piece of viewing software under the total control of the servers it's accessing. Mozilla is the organization meant to protect us from the ever-encroaching desires of industry to control and track what we see online, but instead they're continually giving in to the idea that user agents should serve website operators and ad-tracking networks instead of users. | ||||
|  | ||||
| ## Lack of Consent | ||||
|  | ||||
| Mozilla constantly fails to understand the basic concept of consent. Firefox developers seem to see their position as shepherds, herding the uninformed masses towards choices they interpret to be "good for them." Firefox users are not a captive audience that needs to be coddled, they are generally full-grown adult computer users who need to be listened to. | ||||
|  | ||||
| One Mozilla developer claimed that explaining PPA would be too challenging, so they had to opt users in by default. | ||||
|  | ||||
| <iframe src="https://mastodon.social/@Schouten_B/112784434152717689/embed" class="mastodon-embed" style="max-width: 100%; border: 0" width="400" allowfullscreen="allowfullscreen"></iframe><script src="https://mastodon.social/embed.js" async="async"></script> | ||||
|  | ||||
| <iframe src="https://mastodon.social/@Schouten_B/112784608473016028/embed" class="mastodon-embed" style="max-width: 100%; border: 0" width="400" allowfullscreen="allowfullscreen"></iframe><script src="https://mastodon.social/embed.js" async="async"></script> | ||||
|  | ||||
| The reality is that it isn't simply a *privileged minority* of users who care about surveillance tracking software being built in to their browsers. | ||||
|  | ||||
| Firefox users are **fully** capable of understanding basic concepts like tracking, and can make an informed decision about whether they want their browser to track them. Mozilla refuses to acknowledge this, because it's in their best (financial) interest to get as many people as possible to use this feature. | ||||
|  | ||||
| At the end of the day, Mozilla **knows** this feature isn't something that Firefox users want. If they truly believed this was the one path away from the constant data theft perpetuated by the advertising industry, they would've announced this loudly and proudly. They could've given the privacy and general Firefox communities ample time to scrutinize the protocol beforehand. | ||||
|  | ||||
| Instead, they buried the announcement in a two sentence blurb at the bottom of the release notes, 5 months after they posted a very brief [blog post](https://blog.mozilla.org/en/mozilla/privacy-preserving-attribution-for-advertising/) talking about this technology which was likely ignored by the vast majority of Firefox users. | ||||
|  | ||||
| ## False Privacy | ||||
|  | ||||
| Let's ignore all of this though, and say you don't care that Mozilla is selling out to advertisers, as long as the feature is actually more private than the current status quo. PPA still isn't the answer we are looking for. | ||||
|  | ||||
| The simple truth is that the "Distributed Aggregation Protocol" Mozilla is using here is **not private by design.** | ||||
|  | ||||
| The way it works is that individual browsers report their behavior to a data aggregation server (operated by Mozilla), then that server reports the aggregated data to an advertiser's server. The "advertising network" only receives aggregated data with differential privacy, but the aggregation server still knows the behavior of individual browsers! | ||||
|  | ||||
| This is essentially a semantic trick Mozilla is trying to pull, by claiming the advertiser can't infer the behavior of individual browsers by re-defining part of the advertising network to not be the advertiser. | ||||
|  | ||||
| It is extremely disingenuous for Mozilla to claim that Firefox is adding technical measures to protect your privacy, when the reality is that your privacy is only being protected by social measures. In this particular case, Mozilla and their partner behind this technology, the ISRG (responsible for Let's Encrypt), could trivially collude to compromise your privacy. | ||||
|  | ||||
| ## Uselessness | ||||
|  | ||||
| Finally, there is no reason for this technology to exist in the first place, because tracking aggregate ad conversions like this **can already be done** by websites without cookies and without invading privacy, using basic web technology. | ||||
|  | ||||
| All an advertisement has to do is link to a unique URL: Instead of linking to `example.com` one could link to `example.com/ad01`, and the website operator simply has to track how many people visit the `ad01` page on their end. | ||||
|  | ||||
| In contrast to the amazingly complex PPA setup Mozilla is pushing, this is a perfectly viable alternative that advertisers could easily adopt today. The reason they do not is simply because they have an insatiable need for as much of your data as possible. | ||||
|  | ||||
| ## Disabling PPA | ||||
|  | ||||
| Firefox users should disable this feature: | ||||
|  | ||||
| 1. Open Firefox's settings page at `about:preferences` | ||||
| 2. In the Privacy & Security panel, find the *Website Advertising Preferences* section. | ||||
| 3. Uncheck the box labeled **Allow websites to perform privacy-preserving ad measurement.** | ||||
|  | ||||
| There are also plenty of other [web browsers](https://www.privacyguides.org/en/desktop-browsers/) you could choose from, if you're growing tired of Mozilla's behavior in recent months. Between their foray into generative AI and their business acquisitions in the advertising industry itself, I certainly wouldn't blame you. | ||||
|  | ||||
| PPA is an additional privacy attack surface that has no value for end users whatsoever, as its sole purpose is to give data to the advertising industry for nothing in return. Instead of focusing their efforts on compromising with advertisers, Mozilla could work to actively block unwanted data collection. Because they aren't blocking any of the myriad of ways advertisers currently track you, Mozilla is not acting in your best interest here. | ||||
|  | ||||
| For a browser and organization which has built its reputation entirely on protecting user privacy, these moves are really eroding the trust of its core user base. We hope that Mozilla will listen to the overwhelming user feedback surrounding this feature and their other endeavors, and consider whether these recent actions are aligned with their core mission of putting users first. | ||||
|  | ||||
| --- | ||||
|  | ||||
| [Discuss this article on our forum](https://discuss.privacyguides.net/t/privacy-preserving-attribution-mozilla-disappoints-us-yet-again/19467/2), or leave a comment below. | ||||
							
								
								
									
										174
									
								
								blog/posts/onion-browser-review.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,174 @@ | ||||
| --- | ||||
| title: "Onion Browser Review: Tor on iOS" | ||||
| description: "Onion Browser is our recommended way of connecting to Tor on iOS, but it does have a number of drawbacks compared to the traditional Tor Browser on other platforms you should be aware of." | ||||
| date: | ||||
|     created: 2024-09-18 | ||||
| categories: | ||||
|     - Reviews | ||||
| authors: | ||||
|     - jonah | ||||
| links: | ||||
|     - Tor Recommendations: https://www.privacyguides.org/en/tor/ | ||||
|     - Tor Overview: https://www.privacyguides.org/en/advanced/tor-overview/ | ||||
| tags: | ||||
|     - Tor | ||||
|     - iOS | ||||
| license: BY-SA | ||||
| preview: | ||||
|   logo: theme/assets/img/self-contained-networks/onion_browser.svg | ||||
| review: | ||||
|   type: MobileApplication | ||||
|   category: BrowserApplication | ||||
|   subcategory: Tor Network Browser | ||||
|   name: Onion Browser | ||||
|   price: 0 | ||||
|   website: https://onionbrowser.com/ | ||||
|   rating: 3.5 | ||||
|   pros: | ||||
|     - Officially endorsed way to access Tor on iOS. | ||||
|   cons: | ||||
|     - Some inconsistent and confusing settings. | ||||
|     - Doesn't provide the same protections as Tor Browser. | ||||
| --- | ||||
| { align=right } | ||||
|  | ||||
| Search the App Store for "Tor Browser" and you'll be flooded with a variety of ways to connect to the Tor network from your iPhone. However, there's only one solution officially [endorsed](https://support.torproject.org/tormobile/tormobile-3/) by the Tor Project themselves: **Onion Browser**.<!-- more --> | ||||
|  | ||||
| [:octicons-home-16: Homepage](https://onionbrowser.com){ .md-button } | ||||
| [:octicons-eye-16:](https://onionbrowser.com/privacy-policy){ .card-link title="Privacy Policy" } | ||||
| [:octicons-info-16:](https://onionbrowser.com/faqs){ .card-link title=Documentation} | ||||
| [:octicons-code-16:](https://github.com/OnionBrowser/OnionBrowser){ .card-link title="Source Code" } | ||||
| [:octicons-heart-16:](https://onionbrowser.com/donate){ .card-link title=Contribute } | ||||
|  | ||||
| Onion Browser is an open-source app created by Mike Tigas, who has worked closely with Tor Project in the past and was previously an investigative journalist at ProPublica (he is currently an advisor at the FTC). His company still maintains the app, although lately it is primarily [developed](https://github.com/OnionBrowser/OnionBrowser/graphs/contributors) by other maintainers. | ||||
|  | ||||
| !!! info inline end "Side info" | ||||
|  | ||||
|     - [:simple-appstore: App Store download](https://apps.apple.com/app/id519296448) | ||||
|  | ||||
| We already recommend Onion Browser for any iOS users out there, with the important caveat that it doesn't have all the privacy features that Tor Browser on *other* operating systems would provide. | ||||
|  | ||||
| ## Usage | ||||
|  | ||||
| Of course installing Onion Browser is as easy as any other app on iOS, Apple ID unfortunately required. Onion Browser can be set as your default browser in system settings too, which is nice. | ||||
|  | ||||
| When you open Onion Browser for the first time you're given the option to connect to Tor via [Orbot](https://www.privacyguides.org/en/tor/#orbot), or with a built-in Tor network proxy. Using the built-in option is the easiest, it connects very quickly and doesn't require a separate app. It also allows you to [use Tor alongside another VPN app](https://www.privacyguides.org/en/advanced/tor-overview/#safely-connecting-to-tor), which may be helpful in certain circumstances. The Orbot app acts as its own "VPN connection" in iOS preventing the possibility of combining it with another VPN, but it is more flexible and it extends Tor network protections to every app on your device. | ||||
|  | ||||
| <figure markdown="span"> | ||||
|   { width="200" } | ||||
|   <figcaption>You're presented with a choice at startup</figcaption> | ||||
| </figure> | ||||
|  | ||||
| Using the dedicated Orbot app also provides more robust protections against IP address leaks. Onion Browser warns in its comparison that using the built-in option could leak your IP or network information to malicious JavaScript code. | ||||
|  | ||||
| I confirmed the built-in option works perfectly fine, in fact I occasionally had trouble connecting Orbot to Onion Browser, where it would re-prompt me to start Orbot even though it was already running until I restarted the Onion Browser app. The built-in proxy generally worked seamlessly. However, for most people using Onion Browser alongside Orbot probably still makes more sense. It's the official recommendation from Tor Project and the browser's developer themselves, so that's what I'll be sticking with for the rest of this review. | ||||
|  | ||||
| <figure markdown="span"> | ||||
|   { width="200" } | ||||
|   <figcaption>You can check your connection at check.torproject.org, but you'll be warned you're not using Tor Browser</figcaption> | ||||
| </figure> | ||||
|  | ||||
| Onion Browser comes with 6 `.onion` bookmarks preinstalled: DuckDuckGo, the New York Times, the BBC, ProPublica, Freedom of the Press Foundation, and Deutsche Welle, which provides you with a good entry point into Tor network resources. | ||||
|  | ||||
| <figure markdown="span"> | ||||
|   { width="200" } | ||||
|   <figcaption>You can get started right away with built-in resources</figcaption> | ||||
| </figure> | ||||
|  | ||||
| DuckDuckGo via its `.onion` address is also the default search engine. Unlike Safari, search engines in Onion Browser are completely configurable. Included by default are a few different DuckDuckGo configurations, Google, and Startpage, but you can add your own [search engine](https://www.privacyguides.org/en/search-engines/) easily if you prefer another option. | ||||
|  | ||||
| I ran into trouble with DuckDuckGo not being able to display results, however. Switching to the **DuckDuckGo HTML** search engine in settings helped, and I prefer that more lightweight version myself anyway. I'm curious whether this is a common issue or a momentary glitch with DuckDuckGo, but neither switching circuits nor reducing security levels fixed it. Speaking of... | ||||
|  | ||||
| <figure markdown="span"> | ||||
|   <div markdown="span" style="display: flex; gap: 1em; justify-content: center;"> | ||||
|     { width="200" } | ||||
|     { width="200" } | ||||
|   </div> | ||||
|   <figcaption>DuckDuckGo wouldn't work until I used their HTML-only version</figcaption> | ||||
| </figure> | ||||
|  | ||||
| ### Security Levels | ||||
|  | ||||
| There are three configurable security levels in Onion Browser: Bronze, Silver (the default), and Gold. These levels roughly correlate to the *Safe, Safer, Safest* [security levels](https://tb-manual.torproject.org/security-settings/) in regular Tor Browser. | ||||
|  | ||||
| <figure markdown="span"> | ||||
|   { width="200" } | ||||
|   <figcaption>You can toggle security levels on a per-site basis with two taps</figcaption> | ||||
| </figure> | ||||
|  | ||||
| I had no issues browsing the web in the standard Silver level, which felt similar to just using Safari. Even websites which rely a bit more on JavaScript like our own [forum](https://discuss.privacyguides.net/) were unaffected, so this seems to be a sane default for most people. | ||||
|  | ||||
| The security level toggle next to the address bar is a bit dangerous, in my opinion. It changes the security level on a per-site basis, which can lead to inconsistent settings. I ran into this when I set the security level to Gold on privacyguides.**org**, then I navigated to our forum (hosted on privacyguides.**net**) and found the security level reset itself to Silver. Changing the security level for all sites requires going into the app's settings and changing the default security, which is something to keep in mind if you don't trust the sites you're visiting. | ||||
|  | ||||
| That being said, I also found that even the default security level setting didn't apply itself consistently after changing it. When I set the default security to Gold and opened DuckDuckGo, it opened at the lower Silver security level. I believe this is because I had manually set DuckDuckGo to Silver using the per-site toggle earlier, but changing the default setting *really* should reset those preferences. | ||||
|  | ||||
| The Gold browsing experience definitely broke more websites. Our forum didn't load at all, despite theoretically having a non-JavaScript version available. Other pages had broken elements: I loaded the Freedom of the Press Foundation's homepage fine, but I wasn't able to open the mobile navigation menu with the button in their header without switching back to Silver. | ||||
|  | ||||
| Something to note is that even the Gold level protections don't go nearly as far as Safest protections in Tor Browser. For example, the Safest setting on desktop Tor Browser will block resources like external fonts, which are not blocked on any level by Onion Browser. Onion Browser is meant to be a censorship circumvention tool, but it is not ready to defend your anonymity against any more dedicated adversaries. | ||||
|  | ||||
| ### Other Settings | ||||
|  | ||||
| Onion Browser comes with reasonable defaults and a fairly sparse number of customization options, but there's some you'll probably want to change if you're using this every day. | ||||
|  | ||||
| The **Tab Security** setting defaults to *Forget in Background*, which I found closes your tabs even if you simply check your notifications. It's certainly good that it errs on the side of caution and closes your tabs when you do literally *anything* outside the app, but I think most people will probably prefer this set to *Forget at Shutdown* where the data is only wiped when the app is actually closed. If you're really not concerned about local data storage, you can have the browser remember tabs until you close them for a more standard browser-like experience. | ||||
|  | ||||
| In the **Default Security** settings you can choose a different user agent, or leave it blank to send the default, in which case it sends Safari's default user agent for your device. You may find this useful to change how websites present themselves, but impersonating the user agent of another browser does **not** make you blend in with that browser from a fingerprinting perspective. There are many ways a website could determine what browser you are using outside your user agent, so don't rely on this setting to make you blend in with everyone else using Tor Browser on other devices. | ||||
|  | ||||
| Besides leaving it blank for the default, it comes with three built-in user agent strings you can choose from, or you can enter your own. You might find it useful to use Tor Browser for Android's, but if you have no idea what any of this means it's probably best to leave the user agent settings alone. | ||||
|  | ||||
| === "Default (on my device)" | ||||
|  | ||||
|     ``` | ||||
|     Mozilla/5.0 (iPhone; CPU iPhone OS 18_1 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/18.0 Mobile/15E148 Safari/605.1.15 | ||||
|     ``` | ||||
|  | ||||
| === "Safari Desktop" | ||||
|  | ||||
|     ``` | ||||
|     Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/15.0 Safari/605.1.15 | ||||
|     ``` | ||||
|  | ||||
| === "Tor Browser Desktop" | ||||
|  | ||||
|     ``` | ||||
|     Mozilla/5.0 (Windows NT 10.0; rv:78.0) Gecko/20100101 Firefox/78.0 | ||||
|     ``` | ||||
|  | ||||
| === "Tor Browser Android" | ||||
|  | ||||
|     ``` | ||||
|     Mozilla/5.0 (Android 9; Mobile; rv:78.0) Gecko/20100101 Firefox/78.0 | ||||
|     ``` | ||||
|  | ||||
| The other settings in the app are fairly self-explanatory, but I don't expect many people will need to change them. | ||||
|  | ||||
| ## Drawbacks | ||||
|  | ||||
| A large part of Onion Browser's problems come down to how iOS works. Most notably the iOS requirement for third-party browsers to use the WebKit framework built in to iOS. | ||||
|  | ||||
| This requirement means that Onion Browser has completely separate development from Tor Browser on desktop and Android, so it can't easily make use of all the advanced privacy-protecting features the Tor Project team is constantly adding to their browser. Technically it does also mean Onion Browser has historically been immune to [Firefox-related vulnerabilities](https://blog.mozilla.org/security/2016/11/30/fixing-an-svg-animation-vulnerability/), but Safari is not known for its perfect security record either, and the number of eyes on Tor-related *WebKit* vulnerabilities is certainly far smaller than on *Firefox/Gecko*-related ones. | ||||
|  | ||||
| The Tor Project [notes](https://blog.torproject.org/tor-heart-onion-browser-and-more-ios-tor/) another drawback to Onion Browser's use of WebKit as well: The WebKit APIs simply don't give browser developers the level of control they're used to over the rendering and execution of web pages. This relates to what we saw earlier with the "Gold" protection levels not quite matching what you'd see in Tor Browser on other platforms. | ||||
|  | ||||
| The EU recently required Apple to let third-party browser developers use their own engines instead of WebKit. It's possible that—likely many years from now—a version of Onion Browser or Tor Browser could come to iOS alongside Tor's stricter protections found in their standard browsers. Even still, the mobile version of Tor Browser on Android which *does* use Firefox's mobile engine is leagues behind desktop Tor Browser in terms of privacy and security. It's safe to say that desktop Tor Browser is going to be the best way to access Tor for quite some time. | ||||
|  | ||||
| ## Lockdown Mode | ||||
|  | ||||
| There is one more way to improve Onion Browser security, but we have to look outside the browser to find it. [Lockdown Mode](macos-ventura-privacy-security-updates.md#lockdown-mode) is a feature introduced in iOS 16 that reduces the attack surface of your device by disabling a myriad of features, including web browsing features that could potentially impact security. | ||||
|  | ||||
| Because Onion Browser is built on Apple's WebKit, these security improvements extend to Onion Browser as well. Most notably, external web fonts *are* blocked in Onion Browser with Lockdown Mode enabled, just as they are in Safari. These are disabled in desktop Tor Browser's Safest mode due to both privacy concerns, and security concerns related to the font rendering engine on your device, so having the option to disable them here on iOS is very useful for those looking to maximize their security. | ||||
|  | ||||
| <figure markdown="span"> | ||||
|   { width="200" } | ||||
|   <figcaption>External fonts and JavaScript disabled with Gold + Lockdown Mode</figcaption> | ||||
| </figure> | ||||
|  | ||||
| However, enabling Lockdown Mode *is* detectable by websites, meaning it could potentially be used to fingerprint you. Onion Browser in any form does not really provide the same fingerprinting protections that desktop Tor Browser is able to, so this probably shouldn't stop you from using Lockdown Mode, but it is something to keep in mind. | ||||
|  | ||||
| ## Conclusion | ||||
|  | ||||
| The decision to use Onion Browser will ultimately come down to your specific requirements. If you simply need a web browser that connects to [Tor hidden services](https://www.privacyguides.org/en/advanced/tor-overview/#path-building-to-onion-services), and you're not concerned with being tracked down, this is a perfectly reasonable choice on iOS. | ||||
|  | ||||
| It's also a good way to promote and normalize the use of Tor in general. My browsing experience using Onion Browser, while still a bit slower than regular browsing, was perfectly acceptable for reading the news, searching the web, and other everyday browsing tasks most of us do on our phone. The more people that use Tor for their everyday traffic, the safer the overall network becomes for people who really need it. | ||||
|  | ||||
| Just don't expect the same level of protection that desktop Tor Browser can provide. If you're concerned about serious adversaries targeting you, the safest way to use Tor is still to use it via [Whonix+Qubes](https://www.privacyguides.org/en/desktop/#whonix). | ||||
| @@ -0,0 +1,45 @@ | ||||
| --- | ||||
| date: | ||||
|     created: 2024-07-22 | ||||
| categories: | ||||
|     - Announcements | ||||
| authors: | ||||
|     - jonah | ||||
| description: We're excited to announce a partnership with MAGIC Grants, a Public 501(c)(3) charity with the mission of supporting privacy projects like ours and providing undergraduate scholarships for students interested in cryptocurrencies and privacy. | ||||
| schema_type: BackgroundNewsArticle | ||||
| --- | ||||
| # Privacy Guides Partners With MAGIC Grants 501(c)(3) | ||||
|  | ||||
|  | ||||
|  | ||||
| In February, the OpenCollective Foundation (OCF)—[our fiscal host of 4 years](https://blog.privacyguides.org/2019/10/31/weve-joined-the-open-collective-foundation/)—sent us an email to [announce](https://docs.opencollective.foundation/) that they would be shutting down, and they would no longer be able to collect donations on our behalf (or for any of the hundreds of projects they provided fiscal hosting services to). We immediately began to consider multiple options for the future of this project, including forming our own non-profit or finding another [fiscal host](https://en.wikipedia.org/wiki/Fiscal_sponsorship).<!-- more --> | ||||
|  | ||||
| We're excited to announce a [partnership](https://magicgrants.org/2024/07/22/Privacy-Guides-Fund) with MAGIC Grants, a Public 501(c)(3) charity with the mission of supporting privacy projects like ours and providing undergraduate scholarships for students interested in cryptocurrencies and privacy. They will immediately take over all of the operations previously provided by OCF, including accepting donations on our behalf, handling any of our accounting and taxes, reimbursing team members and volunteers, and taking legal ownership of assets like our domains and servers. | ||||
|  | ||||
| This last point is important, because we want to ensure Privacy Guides is never fully reliant on a single individual like myself. This setup ensures Privacy Guides never strays from its mission of providing free and accessible privacy and security resources to protect consumers. | ||||
|  | ||||
| Of course, all of our projects including the [open-source](https://github.com/privacyguides/privacyguides.org) Privacy Guides website, our communities, and this blog remain editorially independent and volunteer led. This partnership only affects our administrative platform behind the scenes. | ||||
|  | ||||
| MAGIC Grants was the right choice for our project for a number of reasons: | ||||
|  | ||||
| 1. They are a 501(c)(3) non-profit, which allows us to retain our tax deductible status in the United States, and means there are legal safeguards in place to prevent Privacy Guides from being used for personal profit. | ||||
| 2. They've provided us with a great deal of flexibility and independence over how we run our project, and added many safeguards to ensure the current Privacy Guides team retains ultimate control over the project. This means that nothing about Privacy Guides will change, now or in the future, due to outside influence. | ||||
| 3. They've generously offered to provide their services to us for no fee, in support of our shared core mission of creating great educational materials. | ||||
|  | ||||
| Finally, unlike OCF, MAGIC Grants is extremely flexible when it comes to accepting cryptocurrencies. Previously we have not been able to accept cryptocurrency donations, because OCF did not have the accounting tools in place to handle such transactions. MAGIC Grants is highly experienced in the cryptocurrency—and especially [Monero](https://www.privacyguides.org/en/cryptocurrency/)—space, and we will be able to accept completely private donations through that very soon. | ||||
|  | ||||
| Donations to Privacy Guides are considered restricted contributions which may only be used under the [Privacy Guides Fund agreement](https://magicgrants.org/funds/privacy_guides/) we have with MAGIC Grants, and not for any of MAGIC Grants’ other endeavors. You can make a general donation to MAGIC Grants on their [website](https://magicgrants.org/contribute/). | ||||
|  | ||||
| --- | ||||
|  | ||||
| We considered forming our own organization, but estimated that the initial costs to do so would meet or exceed our current annual budget, which wasn't financially viable. We have reserved the right to spin off as an independent non-profit, or to transfer to another fiscal host in the future, if we feel it would be beneficial to do so. | ||||
|  | ||||
| Running this network of websites and services for free to the public is a time-consuming and costly endeavor. We do it because we believe it is the right thing to do, not because we are looking to make a profit. Any contributions have been either used to pay our expenses or saved in a reserve for expansion or times of need. | ||||
|  | ||||
| Your support of this project will help us keep our servers running and pay for other various expenses accrued by the team while developing this community. We do not operate Privacy Guides for personal profit, and all funds will be used to further our mission in one form or another. | ||||
|  | ||||
| If you like what we do, please consider contributing to our project at <https://www.privacyguides.org/en/about/donate/>. | ||||
|  | ||||
| --- | ||||
|  | ||||
| Read more about the [Privacy Guides Fund announcement](https://magicgrants.org/2024/07/22/Privacy-Guides-Fund) on MAGIC Grants' blog. | ||||
							
								
								
									
										131
									
								
								blog/posts/proton-wallet-review.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,131 @@ | ||||
| --- | ||||
| title: "Proton Wallet Review: Is Proton Losing Touch?" | ||||
| template: review-article.html | ||||
| schema_type: ReviewNewsArticle | ||||
| description: "It may well be that Proton Wallet is the easiest way to start using Bitcoin, but is a Bitcoin wallet the solution people need to improve their financial privacy?" | ||||
| date: | ||||
|     created: 2024-09-08 | ||||
| categories: | ||||
|     - Reviews | ||||
| authors: | ||||
|     - jonah | ||||
| links: | ||||
|     - Cryptocurrency: https://www.privacyguides.org/en/cryptocurrency/ | ||||
| tags: | ||||
|     - Cryptocurrency | ||||
| license: BY-SA | ||||
| preview: | ||||
|   logo: theme/assets/img/cryptocurrency/proton-wallet.svg | ||||
| review: | ||||
|   type: SoftwareApplication | ||||
|   category: FinanceApplication | ||||
|   subcategory: Cryptocurrency Wallet | ||||
|   name: Proton Wallet | ||||
|   price: 0 | ||||
|   website: https://proton.me/wallet | ||||
|   rating: 2 | ||||
|   pros: | ||||
|     - Secure, non-custodial option for Proton users. | ||||
|   cons: | ||||
|     - Only supports Bitcoin, a non-private cryptocurrency. | ||||
|     - No support for Lightning or CoinJoin. | ||||
|     - iOS app still in beta. | ||||
| --- | ||||
| { align=right itemprop="image" } | ||||
|  | ||||
| Proton, the Swiss creators of privacy-focused products like [Proton Mail](https://www.privacyguides.org/en/email/#proton-mail) and [Proton VPN](https://www.privacyguides.org/en/vpn/#proton-vpn), recently released the latest product in their ever-growing lineup: **Proton Wallet**. [Announced](https://discuss.privacyguides.net/t/introducing-proton-wallet-a-safer-way-to-hold-bitcoin/19636) at the end of July 2024, it promotes itself as "an easy-to-use, self-custodial" Bitcoin wallet that will ostensibly make financial freedom more attainable for everyone.<!-- more --> | ||||
|  | ||||
| !!! info inline "Side info" | ||||
|  | ||||
|     - Proton Wallet's [Privacy Policy](https://proton.me/wallet/privacy-policy) | ||||
|     - This review was conducted with the reviewer's personal Proton Visionary account. Proton was not contacted prior to this publication. | ||||
|  | ||||
| It may well be that Proton Wallet is the easiest way to start using Bitcoin, but is a Bitcoin wallet the solution people need to improve their financial privacy? | ||||
|  | ||||
| ## A cryptocurrency primer | ||||
|  | ||||
| Contrary to popular belief, [cryptocurrency](https://www.privacyguides.org/en/cryptocurrency/) is not an inherently private transactional system. | ||||
|  | ||||
| The vast majority of cryptocurrency, including Bitcoin, uses a transparent and public blockchain as the ledger for all transactions. This means that anyone you've transacted with or who knows your wallet's public address can trivially trace all of your past transactions, and monitor all of your future transactions at any time. | ||||
|  | ||||
| This is a huge problem for Proton Wallet, because Bitcoin is the **only** cryptocurrency it supports. Furthermore, Proton Wallet doesn't support the few privacy-enhancing additions to Bitcoin that do exist, like CoinJoin or even the Lightning Network. While these technologies still don't bring Bitcoin close to the levels of privacy attainable with some alternatives like Monero, to see them lacking in a product from a privacy-centric company like Proton is extremely disappointing. | ||||
|  | ||||
| Proton has claimed in a few interviews that they chose Bitcoin because of its mass appeal, and it's certainly true that Bitcoin has the mind share and market share to beat out any other cryptocurrency, but the *most popular* option isn't always the *best* option. | ||||
|  | ||||
| Had Proton Wallet added support for Monero or a similarly private cryptocurrency, they could have single-handedly boosted a financial system that is *actually* private by default by a significant degree. In my eyes, failing to do so in favor of the market leader is an unfortunate step back from their "privacy by default" mantra. | ||||
|  | ||||
| ## Using the app | ||||
|  | ||||
| Proton Wallet *is* in beta, like many of Proton's products are when newly released, and available via the web, an Android app, and an iOS [TestFlight](https://testflight.apple.com/join/6OIcXtQN). | ||||
|  | ||||
|  | ||||
|  | ||||
| Creating your wallet is a simple process, after registering you'll be asked to choose a name for your wallet and a default currency. You can also optionally set a passphrase to secure your account. Note that this isn't merely a passphrase securing your account on Proton's servers beyond your usual account credentials, it's a [BIP39 extension word](https://en.bitcoin.it/wiki/Seed_phrase#Two-factor_seed_phrases), meaning that if you lose it your wallet will be completely unrecoverable, **even if** you back up your 12 word seed phrase. | ||||
|  | ||||
|  | ||||
|  | ||||
| The default currency here isn't the currency being *stored* in Proton Wallet. It is just used to show you the current conversion rate between Bitcoin and your local currency. | ||||
|  | ||||
| Once you're in, Proton Wallet is fairly straightforward. In fact, there's not much to explore beyond finding your wallet address and buying Bitcoin. Clicking the **Recieve** button brings up a panel which shows your address and allows you to generate a new one on the fly. When you generate a new address, all of your previous addresses will continue to work, but are no longer displayed anywhere. | ||||
|  | ||||
|  | ||||
|  | ||||
| Buying Bitcoin is simple as well. Proton is working with two providers, Banxa and Ramp, and if you're in the United States like I am both are available, so you can choose the one with the best exchange rate to go with. Before you purchase, Proton Wallet asks you for your current country, so that will determine which providers it's possible to use. | ||||
|  | ||||
| There's no private payment methods though, you're stuck with credit card, Google Pay, or Apple Pay. The purchase experience isn't quite seamless either, as it redirects you to either banxa.com or ramp.network to perform the actual transaction. Everything is pre-filled with your Proton Wallet information however, so it isn't a huge problem. | ||||
|  | ||||
| ## "Bitcoin via Email" | ||||
|  | ||||
| The flagship feature of Proton Wallet is something they call **Bitcoin via Email**, which integrates with Proton Mail to allow you to send Bitcoin to any email address. Opening your wallet settings lets you enable Proton's *Receive Bitcoin via Email* feature, which allows other Proton Wallet users to send Bitcoin to your account with just your Proton Mail address. | ||||
|  | ||||
|  | ||||
|  | ||||
| If you have multiple addresses on your Proton account, such as aliases or addresses on a custom domain, only one address can be linked to your wallet. This can be a bit annoying for people who have given out different Proton addresses to others in the past, like if you gave out your @protonmail.com address to some people, before later migrating to @proton.me when that domain became available. | ||||
|  | ||||
| On the other hand, if you have aliases for different projects, this is a great way to keep Bitcoin payments to each address separate. If you have your personal email and a business alias for example, you can link your personal email to your primary wallet and create a second wallet to link your business alias to, thus keeping your personal and business transactions separate. | ||||
|  | ||||
| Proton says that you can "create as many wallets as your Proton Wallet plan allows," but the exact limits are not very clear at the moment. This may become clearer as Proton Wallet exits its beta status. | ||||
|  | ||||
| Sending Bitcoin to an email address is as simple as it is in mainstream payment apps like Venmo or CashApp, which is great. You can even include a memo with your transaction, and the transaction appears on the recipient's side very quickly. However, it can take a few hours or more for a transaction to actually complete and be usable by the recipient, so all they'll be able to do is monitor its progress in the meantime. This can be sped up by choosing a higher "network fee" when sending the payment, which costs more Bitcoin as the name would suggest. | ||||
|  | ||||
| I'm not convinced this is particularly revolutionary though. Many Bitcoin wallets have streamlined the process of exchanging address information with other people with methods like QR codes, which are likely going to be more widely used than email in today's mobile-first world. Being able to replace Bitcoin addresses with emails fairly seamlessly *is* nice, but is it nice enough to warrant the entire Proton Wallet product? I'm not so sure. | ||||
|  | ||||
| ## What else sets it apart? | ||||
|  | ||||
| There isn't much separating Proton Wallet from the existing options on the market. It is a *non-custodial* wallet, meaning that you control the private keys rather than Proton. This is a huge step-up in security compared to keeping your Bitcoin in an online exchange like Coinbase, but it isn't a big differentiator from other software wallets where non-custodial key storage is typically the norm. | ||||
|  | ||||
| Besides that, and Bitcoin via Email, if you visit Proton's website to see how else they differentiate themselves the best third reason they could muster up is: | ||||
|  | ||||
| > Our business is privacy: Proton isn't a crypto company — we're a privacy company that wants to empower everyone to use Bitcoin securely and privately. | ||||
|  | ||||
| Unfortunately for Proton, this doesn't quite ring true when it comes to Proton Wallet. When it launched in 2014, Proton Mail was revolutionary in the email space. Encrypted email providers already existed, but Proton offered something different: Proton brought a good user experience to an interoperable encryption standard, PGP. While everyone else in the email space was rolling their own password-protected web portals to secure messages or simply delivering emails in plaintext, Proton built a user-friendly platform that actually improved the email ecosystem at large in the process. | ||||
|  | ||||
| Proton's leadership thinks they can do for cryptocurrency what they once did for email, but there's a clear difference between then and now. Proton Mail had privacy and security ready to go from the beginning, but Proton Wallet simply meets the status quo. | ||||
|  | ||||
| ## Why does this exist? | ||||
|  | ||||
| Proton Wallet is in a strange position. I've spoken to a few sources who suggest that privacy features like CoinJoin, which can mix Bitcoin in order to better anonymize transactions, were intended to be included at launch. The [crackdown](https://bitcoinmagazine.com/legal/samourai-wallet-breaking-down-dangerous-precedents) on the ill-fated Samouri Wallet project by U.S. authorities last April certainly put a damper on privacy in the Bitcoin space, and likely made Proton wary of introducing such features to the public. | ||||
|  | ||||
| Proton suggests this themselves, stating on their [website](https://proton.me/wallet/bitcoin-guide-for-newcomers): | ||||
|  | ||||
| > Coinjoin is considered the best solution for improving blockchain privacy. It works by mixing your BTC with other users’ BTC in a collaborative self-custodial transaction where you get back the same amount of BTC that you put in but on a different address that cannot be easily linked to your previous address. However, in 2024, in what many consider to be a regulatory overreach and attack on privacy, some of these Coinjoin services have been declared illegal in the US and EU. The future of financial privacy may therefore be decided by ongoing litigation in the next decade and privacy advocates should support these efforts. | ||||
|  | ||||
| This situation likely soured Proton on other privacy-friendly cryptocurrencies like Monero as well. I get it, financial privacy is an extremely challenging task for any company to take on. We can't expect Proton to take on the risk of offering a completely anonymous payment service in the current legal climate, but it begs the question: why enter the financial space at all? | ||||
|  | ||||
| Proton Wallet seems like a product that doesn't know its own place in the world. Is it meant to save us from the tyranny of payment processors like PayPal who can freeze your funds at a whim? Proton certainly thinks so, having faced that exact problem themselves during their original 2014 crowdfunding campaign. But in that case, is Bitcoin the actual solution to this problem, or is it just a stopgap fix that Proton happened to latch on to way back in 2014 when Bitcoin was more *in vogue* and there were few competitors? | ||||
|  | ||||
| Today, there are many alternatives to Bitcoin which are safer to store your money in while remaining protected from intrusive fintech companies like PayPal. Stablecoins like USDC can be traded on multiple cryptocurrency networks without the need for middlemen payment processors, and can be exchanged at a variety of exchanges with the huge benefit of having *significantly* less risk than Bitcoin, theoretically no risk at all. Support for USDC or a similar technology would go a long way towards enabling *usable* cryptocurrency transactions for everyday users, even though USDC doesn't have any additional privacy protections either. | ||||
|  | ||||
| Or, was Bitcoin chosen to give us independence from fiat currency, including stablecoins, entirely? Maybe so, but is that something we actually want? Prepping for a worldwide market collapse is perhaps a bit of a fool's errand. If the US Dollar and other economies failed overnight, I think we would all have a lot more problems than Bitcoin is going to solve for us. Bitcoin is a poor store of value to serve as an alternative to traditional currency anyway. Any asset which can gain or lose half its purchasing power on any given day of the week simply can't function as a viable medium of exchange, meaning it's virtually useless for day-to-day transactions. | ||||
|  | ||||
| However, if Proton Wallet wasn't meant for all that, if it was simply meant to bring privacy to Bitcoin, then it's certainly a failure. Proton hasn't taken any risks with this product, meaning it's really only good for satisfying a singular belief: That Bitcoin is just inherently good, and anything to promote Bitcoin is inherently good as well. I don't share these fanatical beliefs of *Bitcoin maximalists*, however, when Bitcoin is demonstrably lacking in a wide variety of ways. | ||||
|  | ||||
| ## Conclusion | ||||
|  | ||||
| Personally, I'm a bit of a cryptocurrency pessimist in general, but I can see some appeal for the technology in very specific areas. Unfortunately, Proton Wallet doesn't seem to fit in to a useful niche in any meaningful way. The functionality it does support is extremely basic, even by Bitcoin standards, and it simply doesn't provide enough value over the existing marketplace. | ||||
|  | ||||
| If you're an existing Proton user simply looking for a place to store some Bitcoin *you already have* sitting around, Proton Wallet might be perfectly adequate. For everyone else, I don't see this product being too useful. Bitcoin is still far too volatile to be a solid investment or used as a safe store of value if you crave financial independence and sovereignty, and Proton Wallet simply isn't adequate for [paying for things privately online](https://www.privacyguides.org/en/advanced/payments/). | ||||
|  | ||||
| There is some potential with Proton Wallet. Personally, I would like to see [support for Monero](https://protonmail.uservoice.com/forums/960668-proton-wallet/suggestions/48672359-support-monero), a cryptocurrency that has privacy features built-in by default. There is also the possibility of Proton expanding into the *traditional* finance space with features like a digital wallet for credit/debit cards, card aliasing à la [privacy.com](https://www.privacyguides.org/en/financial-services/#privacycom-us), and tap to pay within their mobile apps. A third-party alternative to Apple Pay and Google Wallet, and for the first time ever such a product could actually be viable: It's always been possible on Android, but just last month Apple announced the possibility for [iOS developers to use NFC](https://www.apple.com/newsroom/2024/08/developers-can-soon-offer-in-app-nfc-transactions-using-the-secure-element/) to facilitate payments outside of Apple Wallet. This presents a golden opportunity for Proton Wallet to be the first cross-platform digital wallet, if they can deliver. | ||||
|  | ||||
| Alas, none of this is available in Proton Wallet today, and that's all that really counts. | ||||
							
								
								
									
										45
									
								
								blog/posts/pwa-vs-iwa.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,45 @@ | ||||
| --- | ||||
| date: | ||||
|     created: 2024-11-30 | ||||
| categories: | ||||
|     - Opinion | ||||
| authors: | ||||
|     - fria | ||||
| tags: | ||||
|     - PWA | ||||
|     - IWA | ||||
|     - Web | ||||
| license: BY-SA | ||||
| --- | ||||
| # State of the Web App: Current Woes and Promising Futures | ||||
|  | ||||
| The concept of a [progressive web app](https://developer.mozilla.org/en-US/docs/Web/Progressive_web_apps) is enticing: an application using web technologies that is inherently cross platform (since it runs in a browser) and acts like a native app, even functioning offline. Support for PWAs in traditionally locked-down platforms like iOS means that PWAs can give users the freedom to install apps without having to go through Apple’s App Store. But there are problems with web content that PWAs haven't solved.<!-- more --> | ||||
|  | ||||
| ## Current Web-Based Apps | ||||
|  | ||||
| Attempts at similar things have been made before, the most infamous of which is [Electron](https://www.electronjs.org). Electron is a software framework that allows developers to easily create cross-platform apps by essentially bundling an entire Chromium browser in with the app. This approach has its [drawbacks](https://usa.kaspersky.com/blog/electron-framework-security-issues/28952/?srsltid=AfmBOor_UcYY-84soHz5K2ULTmhlX44-DsIfJp_StotBrusD63MweSGO), though. Browsers have huge attack surface so it's important to keep them updated with the latest security fixes, but many Electron apps ship outdated versions, leaving those apps vulnerable. Each Electron app has its own version of Chromium with its own attack surface, amounting to a performance and security nightmare. In contrast, PWAs use the browser that you already have installed, so as long as you keep it updated, all your apps will have the latest security fixes. | ||||
|  | ||||
| So why isn't every Electron app shipping as a PWA? The answer is an age-old problem with web content: the fact that you have to trust the server fully. You make an HTML GET request and you're served the content (i.e., the site's HTML, CSS, and JavaScript), but if the server is compromised, you'll be served a compromised website. You also need to rely on the security of DNS name resolution and the [certificate authority](https://www.digicert.com/blog/what-is-a-certificate-authority) system. This is a huge problem for security-sensitive applications like messengers. An attacker that gains access to their server—even just temporarily—could distribute compromised clients to millions of people, potentially breaking E2EE or executing a host of other malicious actions. | ||||
|  | ||||
| ## Improving Web Apps | ||||
|  | ||||
| A typical native app is downloaded onto your computer from some kind of trusted place like an app store and only receives updates when the developers push them out. Additionally, there's usually a process of checks and verification before that happens, like Apple's [App Review](https://developer.apple.com/distribute/app-review) and the Google Play [App Review](https://support.google.com/googleplay/android-developer/answer/9859455) process. In contrast to PWAs, with which the threat of an attacker with server access constantly looms, it's much more difficult to target a particular person. In other words, a malicious app update is much less likely to escape scrutiny than a highly targeted attack via compromised servers. | ||||
|  | ||||
| Isolated Web Apps (IWAs) build on the work done on PWAs and [Web Packaging](https://github.com/WICG/webpackage). They are a specification that allows web content to be distributed offline outside of a browser, much like a traditional app. It can be signed just like a regular app too, allowing you to verify that it came from the proper place and hasn't been modified. You could install an IWA from your favorite app store just like any other app and have the same security assurances. This would be incredibly useful in allowing for cross-platform E2EE web apps that don't need to trust a server every time you use them. | ||||
|  | ||||
| Google [distinguishes](https://chromeos.dev/en/web/isolated-web-apps) between the drive by web, PWAs, and IWAs. The drive by web requires more conservative access to the system as the most accessible and is therefore least trusted. PWAs are a bit more trusted and can integrate a bit more deeply into the system as a result. IWAs are the most trusted and, as such, can have deeper access into the system and more powerful capabilities. | ||||
|  | ||||
| <figure markdown> | ||||
|    | ||||
|   <figcaption>source: <a href="https://chromeos.dev/en/web/isolated-web-apps">chromeos.dev</a></figcaption> | ||||
| </figure> | ||||
|  | ||||
| This higher security assurance from isolated and signed web applications and the inherently more trusted nature of a natively installed app will allow for IWAs to safely access APIs which wouldn't be safe to allow normal websites to access, like [Direct Sockets](https://github.com/WICG/direct-sockets/blob/main/docs/explainer.md). | ||||
|  | ||||
| IWAs use a totally new [URL scheme](https://github.com/WICG/isolated-web-apps/blob/main/Scheme.md) since they're not relying on HTTPS certificate authorities or DNS. They're totally isolated from each other and the web using enforced Content Security Policy and Cross-Origin Isolation, hence the name. | ||||
|  | ||||
| ## Issues | ||||
|  | ||||
| The [Worldwide Web Consortium](https://www.w3.org) currently has an open issue on their GitHub for IWAs with some interesting discussions that are worth checking out. There are some [criticisms](https://github.com/w3ctag/design-reviews/issues/842#issuecomment-1989631915) of IWAs, at least in their current form. A big point of contention is giving IWAs access to more powerful features like raw TCP and UDP socket access, similar to what a natively installed app might be able to do, which Martin Thomson at Mozilla argues is dangerous even with user consent. Martin wrote a nice in-depth [article](https://lowentropy.net/posts/bundles) on bundling web content that's worth checking out on their website. It'll be a long process of iterating on the design before a version of this idea that's secure and available across browsers. | ||||
|  | ||||
| Right now, Chrome ships the feature [enabled by default](https://chromestatus.com/feature/5146307550248960) but only on ChromeOS for admin-controlled machines and select development partners of Google. Safari and Firefox haven't implemented the feature, with [Firefox](https://github.com/mozilla/standards-positions/issues/799#issuecomment-2342084330) taking a stance against it. Perhaps in its trial run, the technology will prove its potential, or maybe IWAs aren't the best solution after all and another attempt at improving web apps will come along. I'll be watching with great interest either way. | ||||
							
								
								
									
										45
									
								
								blog/posts/relisting-startpage.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,45 @@ | ||||
| --- | ||||
| date: | ||||
|     created: 2020-05-03 | ||||
| categories: | ||||
|     - Announcements | ||||
| authors: | ||||
|     - contributors | ||||
| links: | ||||
|     - Search Engines: https://www.privacyguides.org/en/search-engines/ | ||||
| tags: | ||||
|     - Search Engines | ||||
| description: Startpage has been relisted in our search engine recommendations following their open communications with the Privacy Guides community. | ||||
| schema_type: NewsArticle | ||||
| --- | ||||
| # Relisting Startpage.com | ||||
|  | ||||
|  | ||||
|  | ||||
| Dear *Privacy Guides* Community, | ||||
|  | ||||
| In October 2019, we learned that System1 had become the majority shareholder in Startpage.com via a new System1 subsidiary, Privacy One Group. Due to the uncertainty surrounding the acquisition and the initial lack of clear communication from the Startpage team towards the privacy community, we were forced to delist Startpage from our [search engine recommendations](https://www.privacyguides.org/en/search-engines/).<!-- more --> In an [explanatory blog post](delisting-startpage.md), we asked for more clarity surrounding the situation, stating: | ||||
|  | ||||
| > ...there are still so many unanswered questions, we can no longer recommend the service with good confidence. If Startpage aims to be re-considered, they will have to answer the questions above, preferably along with an explanation of why it took them so long to get proper answers out to the public. | ||||
|  | ||||
| Shortly after this, the *Privacy Guides* team was able to get an open line of communication with Startpage.com CEO Robert Beens, who vocalized his regret for not answering our questions more quickly and providing more clarity to the community from the start. From their perspective nothing fundamental had changed due to the acquisition, except that they would now have the resources to market Startpage efficiently thanks to System1. Unfortunately, Startpage failed to put themselves in the place of their users, and understand that their lack of transparancy at the beginning would erode the trust they shared with the privacy community. | ||||
|  | ||||
| By December, Startpage had [responded](https://code.privacyguides.dev/privacyguides/privacytools.io/issues/1562#issue-737) to our questions. More recently they also clarified that [System1's privacy policy](https://web.archive.org/web/20201110100140/https://system1.com/terms/privacy-policy) does not relate to Startpage; Startpage's privacy policy remains [unchanged](https://web.archive.org/web/20201110100140/https://www.startpage.com/en/privacy-policy/): | ||||
|  | ||||
| > Having a new shareholder in the company will not change any aspect of the privacy we offer. We are a Dutch company and will continue to be so, fully complying with Dutch and EU privacy regulations (GDPR). We don’t store or share any personal data. No change either. Our clear privacy policy will stay the same. Management / founders (including myself) continue to have an important stake in the company and will continue to be fully committed to our privacy mission! | ||||
|  | ||||
| They also created new support pages clarifying the privacy implications of System1's relationship with Startpage: | ||||
|  | ||||
| - [Startpage CEO Robert Beens discusses the investment from Privacy One / System1](https://web.archive.org/web/20201110100140/https://support.startpage.com/index.php?/Knowledgebase/Article/View/1277/0/startpage-ceo-robert-beens-discusses-the-investment-from-privacy-one--system1) | ||||
| - [What is Startpage's relationship with Privacy One/System1 and what does this mean for my privacy protections?](https://web.archive.org/web/20201110100140/https://support.startpage.com/index.php?/Knowledgebase/Article/View/1275/0/what-is-startpages-relationship-with-privacy-onesystem1-and-what-does-this-mean-for-my-privacy-protections) | ||||
| - [What is the Startpage privacy-guarding data flow?](https://web.archive.org/web/20201110100140/https://support.startpage.com/index.php?/Knowledgebase/Article/View/1276/0/what-is-the-startpage-privacy-guarding-data-flow) | ||||
|  | ||||
| Additionally, Beens joined an [interview](https://invidio.us/watch?v=h-3fW0w2ayg) with Techlore in February answering his questions and further questions from the privacy community. | ||||
|  | ||||
| We prepared a [merge request](https://code.privacyguides.dev/privacyguides/privacytools.io/pulls/1592) in December for relisting Startpage in case we decided to do so, but did not have plans to merge it until the whole team felt confident (which we knew would take time). 5 months later, we sync'd up as a team, and decided to re-list them (with a warning explaining these events) which you can now find on our website [here](https://web.archive.org/web/20201110100140/https://www.privacytools.io/providers/search-engines). Our confidence and trust in Startpage has grown, and we're appreciative of Startpage's cooperation and willingness to address the concerns of our community. | ||||
|  | ||||
| We also hope this encourages any services that may end up being delisted for one reason or another to take action and improve themselves in this same fashion. We don't like delisting the services we've previously trusted and recommended, and we are always happy to see when steps are taken to regain community trust. | ||||
|  | ||||
| --- | ||||
|  | ||||
| **2023-10-23:** This post has been edited to reflect the team's move from [PrivacyTools](https://www.privacyguides.org/en/about/privacytools/) to Privacy Guides. | ||||