Compare commits
	
		
			1048 Commits
		
	
	
		
			v2.0.1
			...
			2024.04.08
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| a1b01b8b8c | |||
| 9626aabea8 | |||
|   | a7a8817c21 | ||
|   | d17adf0299 | ||
| dec6fbb64c | |||
|   | f35e64a4f4 | ||
| af45bcc642 | |||
|   | 66225f2eff | ||
| c2fce11a64 | |||
| cf43545f57 | |||
|   | cca4759612 | ||
|   | 492facf194 | ||
|   | 472a3a5416 | ||
|   | 3a8c0a9e66 | ||
| 0f17a9dce9 | |||
| 464d7ec3c6 | |||
|   | b6d2c6f113 | ||
| 895a83b841 | |||
| ce7896c07f | |||
|   | 04c37b9cdf | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | b12887310f | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | ff0a5339a8 | ||
| 632761cae1 | |||
| b536928661 | |||
| 1372587017 | |||
| 82ab189d36 | |||
| 139a206367 | |||
| 4b92316774 | |||
| fc19f44c18 | |||
|   | 0b43cb1fc7 | ||
|   | 9a56bd46b1 | ||
| 9169afa79a | |||
|   | 6aa14e8eb1 | ||
| f37e72084c | |||
|   | d050d27767 | ||
|   | e5d9d1d055 | ||
| a31dcb6df8 | |||
| 525a2c1137 | |||
|   | c5bdbbcdcb | ||
|   | 48abc1d42a | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | f77fbc6a45 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 01b3a7d48f | ||
|   | 792fc00b06 | ||
| d022f53e6b | |||
| 3b69c565a3 | |||
|   | 2b8869882c | ||
|   | bfa4b0f422 | ||
|   | 3ad66a447f | ||
|   | aaa843d272 | ||
|   | d8627a1ad2 | ||
|   | ae0800e8ec | ||
|   | df824ee0e3 | ||
|   | 298c3cde2b | ||
|   | dd492b272a | ||
|   | 67614c3e17 | ||
|   | 05e5832161 | ||
|   | 0140f0ab7e | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | b477409747 | ||
|   | f60fcf4b2f | ||
|   | 5b09c59a7c | ||
|   | 6b7f2bca03 | ||
| 5d76e2ae0b | |||
| df13d33a09 | |||
| c64814d41a | |||
|   | 63270a3e8c | ||
|   | e388e84dc5 | ||
|   | b0aa86f8dc | ||
|   | 46b462ad72 | ||
| 7011b007a0 | |||
| a890fc47af | |||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 3f0ba17dcc | ||
|   | f6f800d49f | ||
|   | 97996b9397 | ||
|   | 0d0c272a5d | ||
|   | 546e728188 | ||
|   | 8e3bd2589e | ||
|   | cd4181a7fc | ||
|   | 3f26dd3b27 | ||
|   | 8a25c48f57 | ||
|   | f098042357 | ||
|   | f12573d40b | ||
|   | 2043e644c3 | ||
|   | ede201f76d | ||
|   | 96d857da21 | ||
|   | 73188e1a21 | ||
|   | 8ea30ebd7f | ||
|   | fe121cf0d5 | ||
|   | 7c0ff5824a | ||
|   | a650d015fc | ||
|   | 33aecf011a | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | e756ae4b37 | ||
|   | f1e6db05b5 | ||
|   | 1634bea9d2 | ||
|   | 01c19281f7 | ||
|   | f1864a4062 | ||
|   | a1523e3f81 | ||
|   | c89d1ed25f | ||
| 667a207010 | |||
|   | b856a51785 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 9d0a2de9a1 | ||
|   | e9cde5c75d | ||
|   | 93081f84c7 | ||
| e182583a17 | |||
| 8167166eb9 | |||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 772cd517cf | ||
| 2a4885ed39 | |||
| 7ebe767518 | |||
| 9e40a3ece5 | |||
|   | 084a0f9427 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | fe127bed0f | ||
|   | fce4ad5a6b | ||
|   | ee4ff2d41b | ||
|   | 54f37e7f53 | ||
|   | 9e247fcbe6 | ||
|   | 019c9d46f9 | ||
|   | 9d877250f9 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | ee1c13db4c | ||
|   | bb04a71b59 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 60db942814 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 6c771e2ea8 | ||
|   | 8b7a0e3233 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | b7f20342f2 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | efcd5159c8 | ||
|   | aca6b565a7 | ||
| 5808953199 | |||
|   | dc054d91e0 | ||
|   | 2fbc674986 | ||
|   | 239ac0d9e9 | ||
|   | 55dd7465d2 | ||
| cf96d55027 | |||
|   | a896a1a306 | ||
|   | b7f0b672a2 | ||
|   | 7004d344ac | ||
|   | 461ac8f224 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | c8dc59c134 | ||
|   | f8570a4c6a | ||
| 9d285e3094 | |||
| abc22993cb | |||
| e56081202d | |||
| 6da9b15464 | |||
| d5a31c88bb | |||
| d9ff08381f | |||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | e6149a97d9 | ||
| b69edfefd6 | |||
|   | d419ac9432 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 708b1917a7 | ||
|   | 741fb9d904 | ||
| 05228b4db3 | |||
|   | aa9fed4eac | ||
|   | 3db638b937 | ||
| 43b346a5ff | |||
|   | de216b9cde | ||
| add980a655 | |||
|   | 58d6e4e044 | ||
|   | 366e44a940 | ||
|   | b3a26717cd | ||
| b0b6434f28 | |||
| 42bce85c7f | |||
| aa54b66a03 | |||
| 122646d0f8 | |||
|   | 9bd5e84d32 | ||
|   | 025a07e658 | ||
|   | 4621a11016 | ||
|   | 46d2d50842 | ||
| 3dbc2f0083 | |||
| 06fc5e9f1d | |||
| 880bfd3cb2 | |||
|   | f37cd9e7f2 | ||
|   | 78eb8f8eac | ||
| 0a83385de0 | |||
|   | a85690b306 | ||
|   | 38dcfbb3e1 | ||
|   | 95516f6344 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | edae556a2a | ||
|   | d52e533fa2 | ||
|   | e7686c1cc1 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | d94da5094f | ||
|   | 4caef8ef1e | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 42de2565ba | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 5d6992bf76 | ||
|   | 4867ca9b79 | ||
|   | 19119a4c03 | ||
|   | e619ccaf28 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | e44e24d77f | ||
|   | 465e499db1 | ||
|   | e277417ab2 | ||
| 659a03be58 | |||
|   | f69e1ad6af | ||
|   | 94599e568d | ||
|   | d653735a3b | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | ddc800d6e4 | ||
| 83ea0d0774 | |||
| b6d8df1239 | |||
|   | 821f35eb37 | ||
| 2d0c5ea9a7 | |||
| abaca70f2f | |||
|   | 4eae08712d | ||
| af3f279d29 | |||
|   | e40f3979b9 | ||
|   | 3f48629ed3 | ||
| 9fa7184a24 | |||
|   | 8c8c4e1009 | ||
|   | 6f9cf58da1 | ||
|   | 51230eb68f | ||
|   | 3a52e6986b | ||
|   | 966626d9e2 | ||
|   | 5a04889a9e | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 813936b51b | ||
| cf0d62ef7c | |||
| 1c9a1a805d | |||
|   | 1502f1b36c | ||
| a5327ff4d1 | |||
|   | 911c0b5f24 | ||
| e90fd2377d | |||
|   | 1fe5320bbe | ||
|   | 45ff07147d | ||
|   | 509397d6e7 | ||
|   | 8809550e58 | ||
|   | 61ad5103fb | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 7429f0b8b1 | ||
|   | dcd5cc05dd | ||
|   | de75a19b2c | ||
|   | e3beac9e01 | ||
|   | 794591bbd5 | ||
|   | 2029ecbb8d | ||
|   | f55467fc01 | ||
|   | e9a7b27cf2 | ||
| 278c462466 | |||
| 96da882689 | |||
|   | 1487ad6dca | ||
|   | 522c5e92ef | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 6849228388 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 472ab56d50 | ||
|   | d8c8a631ee | ||
|   | c23c06c11b | ||
|   | 2ddb046a4b | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 1a8fda242e | ||
|   | 92d5d9d1ac | ||
|   | e356ae9212 | ||
|   | ef7bd365cc | ||
|   | 8c69fa78d0 | ||
|   | 87b1377e85 | ||
|   | 94da846afc | ||
|   | 42c1611420 | ||
|   | caae79bea2 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | fde6019469 | ||
|   | cc077e63c8 | ||
| ff60d624fc | |||
|   | f3144efeb2 | ||
| 0faf548111 | |||
|   | 60c7a0970f | ||
| 3daeea597d | |||
|   | 972df273e1 | ||
| b8b62c18df | |||
| e09e35dfdf | |||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 90a96896a7 | ||
| 8b09671052 | |||
|   | f439e0be46 | ||
|   | 7220531861 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 72166bb3f1 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 2998c52d7c | ||
|   | c19c1599cb | ||
|   | d47c737a73 | ||
|   | 5f45dd9147 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 57056566b4 | ||
|   | 42fe93a194 | ||
| b42e62e822 | |||
|   | 6cdd3ed34b | ||
| 93462d6ea7 | |||
|   | 3016dc4bc8 | ||
|   | ef990bf0f2 | ||
|   | ad94d0ebe9 | ||
|   | 186e7a2b47 | ||
|   | fa2ed271ef | ||
|   | 97ed4c7279 | ||
|   | 65a4e306eb | ||
|   | 7de8b90cb0 | ||
|   | c5d14debd1 | ||
|   | a2b1f8adf9 | ||
| ca6236da58 | |||
| a5c761c237 | |||
|   | 86f8fda8a5 | ||
| fe0f0d1ce3 | |||
|   | 18f76a9068 | ||
| e41d5eae11 | |||
| d03114fd33 | |||
| b1fcc23d0f | |||
| 3d2d6fb726 | |||
|   | 32969c9fc5 | ||
| 31f3319951 | |||
|   | 70366045d5 | ||
|   | 8c438b8183 | ||
| ![Privacy Guides [bot]](/assets/img/avatar_default.png)  | 2df3405598 | ||
| ebfb448ed2 | |||
| fc12732e93 | |||
| 0e457065a0 | |||
| b074ed9401 | |||
|   | b4804752e1 | ||
| 4c805daa7e | |||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 416f468a20 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 1f6dfc4e6f | ||
| ![Privacy Guides [bot]](/assets/img/avatar_default.png)  | 4847c25066 | ||
| 6582156917 | |||
| e29ed5de35 | |||
| 09b4799dbf | |||
| d1c4abcd4f | |||
| 77c073c602 | |||
|   | d25b4021d5 | ||
| 37632d93ec | |||
| 321eccb7d6 | |||
| aefa3e75c4 | |||
| 8fc748109d | |||
| 7b75ad0514 | |||
| a88689fb43 | |||
| 3f5bbbd492 | |||
| 3499498be7 | |||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 1bde6c2920 | ||
|   | 14b2f975e2 | ||
|   | 29658d1d98 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 3e7d6c6ac2 | ||
| 60f0a8df9f | |||
| 9112720140 | |||
|   | c99bdda06f | ||
| 3849c523ef | |||
|   | 9e35e2ef8a | ||
| 5bad28ff6d | |||
| 3955114451 | |||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | d2316dd782 | ||
|   | 99618de520 | ||
| 5c41b3c2f2 | |||
| ac8c5a30d1 | |||
| 45bfe22c61 | |||
| 65db9d3fee | |||
| f3f092d1a3 | |||
| 35c95c029c | |||
| 7fb07925ec | |||
|   | dc4199d7c4 | ||
| fda35b5f70 | |||
|   | 9e16a63caa | ||
| 47377df8da | |||
| 28c576110c | |||
| d63dc04aff | |||
| e336699480 | |||
| aaec10b83e | |||
| 9cbebf239b | |||
| 97350b6245 | |||
| ![Privacy Guides [bot]](/assets/img/avatar_default.png)  | f0621e257b | ||
|   | 1ac4dd75c7 | ||
| 4c8cd3f295 | |||
|   | bfaba1cd11 | ||
| 66efe4a27f | |||
|   | 657e977074 | ||
| f516235dd4 | |||
| cc696093ce | |||
| 4da25bc39a | |||
| 6245ed8581 | |||
| d9b9092ac3 | |||
|   | 7a6fc90114 | ||
|   | ef7cf862d4 | ||
| f396afa15f | |||
| 227609f768 | |||
|   | 425914a33d | ||
|   | 131f91ad56 | ||
|   | 9b008f2b76 | ||
|   | 2a4947bd72 | ||
|   | 829883c450 | ||
|   | e52286a1b0 | ||
| 2a85daa3fa | |||
| 052671197b | |||
| f6ca66bbb4 | |||
|   | d03f91b1c0 | ||
|   | 74928bb4c7 | ||
| ![Privacy Guides [bot]](/assets/img/avatar_default.png)  | 7b6a158e4d | ||
| 2150385184 | |||
| 561f6a7463 | |||
|   | 23b7effac9 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 1cd29c6972 | ||
|   | ebf28c2b35 | ||
|   | 3498602fdd | ||
|   | 7c6ebc5ebb | ||
|   | d011fe716e | ||
|   | 428121c0c7 | ||
|   | 3361de1705 | ||
| 242894c291 | |||
| d67dcaea11 | |||
|   | e901d0db22 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 815739b7bc | ||
|   | 1b9d8f9c14 | ||
| 70a6cda9d5 | |||
|   | e6f6498908 | ||
|   | 687a36e7db | ||
|   | 94fa083700 | ||
|   | 752db84b86 | ||
| d5a732e08c | |||
| 2746861567 | |||
| f4f28ce821 | |||
|   | b0ce8cea24 | ||
| 43cdf87ad3 | |||
|   | 9782ddf60f | ||
| 8ffa8207ff | |||
| ff30001aff | |||
|   | 145e0af811 | ||
|   | e91f63045d | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 790293b792 | ||
| d4f1195bb3 | |||
| e4d89b0894 | |||
|   | a9a7864889 | ||
|   | d6bab0c4f8 | ||
|   | 27fe6a4c41 | ||
|   | bd1ff328a7 | ||
|   | 64d736a7ef | ||
|   | a1e40a79ba | ||
|   | baece71b49 | ||
|   | f5910c4b2b | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | d35437cafa | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 41bb717191 | ||
|   | fdb59b32b9 | ||
|   | c1f8a1e00c | ||
|   | 070a9b157c | ||
|   | a17363080e | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | f714a82d84 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 3efe31dc29 | ||
|   | 670331bcd9 | ||
|   | bd5506bab8 | ||
|   | eb2fd3bccb | ||
|   | 478c2cee3b | ||
|   | dd96ff1b56 | ||
|   | 2c61157cbc | ||
|   | a110fb0489 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | b66845af14 | ||
|   | 39f67789c4 | ||
|   | 603bec291e | ||
|   | 80f1e8ca51 | ||
|   | fa9faa5648 | ||
|   | 95126762a6 | ||
|   | 0d597160cf | ||
|   | dc0cd7d35f | ||
|   | 10812ede81 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 53b2c2af89 | ||
|   | 78e0cf7a42 | ||
|   | 0c2b119089 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 22572e096f | ||
|   | 41215f7433 | ||
| 750b73c589 | |||
|   | 2edd012619 | ||
|   | 2172eab26a | ||
|   | 724b70ae51 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | b9937e8630 | ||
|   | 303bf1aff6 | ||
|   | ba435096f3 | ||
|   | 3ae6f80797 | ||
|   | 67535a820c | ||
|   | c7ff34b330 | ||
|   | 703c291ba3 | ||
|   | e3ee1cf1bb | ||
|   | ae171cee7b | ||
|   | c477e7af46 | ||
|   | c113f03264 | ||
|   | b6167fda1a | ||
|   | 9525deaf51 | ||
|   | 9911fa781e | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | dc75bcf42e | ||
| 43c7b5329d | |||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 3f6cc30f06 | ||
|   | 05cb8ee35c | ||
|   | 6a469b1fa6 | ||
|   | 78a8f8c061 | ||
|   | 8979e0ce79 | ||
| ed873cd800 | |||
| 4f8663321a | |||
|   | b20785b3b6 | ||
|   | 31bc2cd5af | ||
| 1b5d83137c | |||
| e7d22bb1f2 | |||
| ab5c9f8222 | |||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | b4c0aac903 | ||
| 5f4f23ea65 | |||
| 887022c7c0 | |||
| b9612deb98 | |||
| c4f5871160 | |||
| f5dac93435 | |||
|   | 0a98bcb36b | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 4815008e23 | ||
|   | acd802e15e | ||
| ef657b4afd | |||
| 8afb128ce3 | |||
|   | d4266679b3 | ||
|   | 1be248c1ca | ||
|   | 1ec3dbf27c | ||
|   | 95a14f35d7 | ||
|   | 812558db5c | ||
|   | 7a3fdd42ab | ||
|   | a263b5a95a | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 27fec327fd | ||
|   | 6c9dc8c5d4 | ||
|   | 7f09bd69a9 | ||
|   | 226b9f7885 | ||
|   | a74b6cc7bc | ||
|   | f3086e4416 | ||
|   | 126805b5ba | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 4235d62136 | ||
|   | a87d5cb227 | ||
|   | df90475594 | ||
|   | ebf589096b | ||
|   | 64c7e30e37 | ||
| afc078b9f4 | |||
|   | ee70f568dc | ||
| 3ab0c984e8 | |||
|   | aaff8259d4 | ||
|   | 9c85a65190 | ||
| 23a2419dc8 | |||
|   | a1bd21f365 | ||
|   | 5bf2e8bf1f | ||
|   | bc8045c2a0 | ||
|   | faf6d34ec1 | ||
|   | 02c65f45e3 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 666df1dd65 | ||
|   | 7c84c44b3d | ||
|   | 1cc1bd3ad6 | ||
|   | 21f5b7f84f | ||
|   | befce0f1d9 | ||
|   | 23c74a6dc3 | ||
|   | b92347cba3 | ||
|   | e7f8f1c8c0 | ||
|   | 70c0905b2b | ||
|   | 36528b2eb8 | ||
|   | f7258ebe8d | ||
|   | 2dd8e847f6 | ||
|   | 1dbcac4d5b | ||
|   | 688abddc43 | ||
|   | bca9692c37 | ||
|   | f2162cf28a | ||
|   | 4c159a3261 | ||
|   | b3a254463d | ||
| 2b58befda4 | |||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 0b8edd035c | ||
|   | 9f6cd454a8 | ||
|   | 8309e56cb3 | ||
|   | c88dc960d2 | ||
| 2c5707a9ba | |||
|   | cc3bcd9d94 | ||
|   | 982dc64730 | ||
|   | 0660fbf119 | ||
| 9d14330cde | |||
| 16cb2daf2a | |||
| 173a9b6d30 | |||
|   | 429c643866 | ||
|   | a974b8485c | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 667996df8d | ||
|   | 93663bca8e | ||
|   | 66bb715834 | ||
| ecbc75e955 | |||
| dd87672a73 | |||
|   | e07feb8aa9 | ||
| 72f74406b9 | |||
|   | 193a8d512a | ||
|   | 137f16d0a9 | ||
|   | 35af82b3f1 | ||
|   | 8cc83258b7 | ||
| 7e1f0196f9 | |||
|   | 54e8229454 | ||
| 2e3cecf285 | |||
|   | 13c05dc07f | ||
| 0ba070dc8e | |||
| 5f970c58ac | |||
| b5205aee77 | |||
| f85803d5c1 | |||
| b3c976b694 | |||
|   | 41f785b0fd | ||
|   | 3803bdd72d | ||
|   | b373e23429 | ||
| ba7b53aceb | |||
| f255d49760 | |||
| 88bb0721eb | |||
| 7a594bbf27 | |||
|   | eddfd29cfe | ||
| c72ae5fb3c | |||
| 2098040200 | |||
| a7816299f3 | |||
| 3db5cffecd | |||
|   | 65179b83e9 | ||
|   | 3874ff4919 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 8b6f0397bb | ||
|   | 313ca0b50f | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | f288f840dd | ||
| 3af8be9b88 | |||
| c593ce9ed3 | |||
|   | 79f898a2dd | ||
| 4ea7ae8f7b | |||
| 9cfe06f714 | |||
| a7505190d4 | |||
|   | 605b0fd954 | ||
| e32404f85a | |||
|   | 61acc755c6 | ||
|   | 3d8c8d969c | ||
|   | 68096ef2ab | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | df94276c31 | ||
|   | 8040c32810 | ||
|   | 76f5417f04 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 208c738b83 | ||
|   | 432ee9898e | ||
|   | c120e07c25 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 8563ee9ec9 | ||
| 2f9c779b15 | |||
| 5fa9a3b505 | |||
| 3b0cd75cbd | |||
| 12fc2d8a9b | |||
|   | e9b951cb68 | ||
|   | 95d653f26e | ||
|   | bd4818e993 | ||
|   | 16237ad930 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 347d09a4c2 | ||
| 0ab8b1f8f2 | |||
| 4f091b65e2 | |||
| 86ee500c6d | |||
|   | 005c6fe7cd | ||
|   | bd5ef054ea | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 182d76b2ae | ||
|   | 67f1526d19 | ||
|   | ef4db53567 | ||
|   | 8535dadcad | ||
|   | e1f5a00d90 | ||
|   | 3b12f672f0 | ||
|   | 462db2bdfa | ||
|   | 2abaf2f4dd | ||
|   | a0ebda314e | ||
|   | 5334e869ed | ||
|   | 011efec32b | ||
|   | 1c527faa04 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | ca9a13c544 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 0d0a0a822c | ||
|   | ef286ae706 | ||
|   | d421e81045 | ||
|   | 2176a3a2de | ||
|   | 65874da53c | ||
|   | b3ceb64052 | ||
|   | ab0b61db10 | ||
|   | 31ff6160eb | ||
|   | 960a328ea7 | ||
|   | 3111447b96 | ||
|   | b506f74950 | ||
|   | e0933d6521 | ||
|   | 2d6b59e94b | ||
|   | 7a73aae321 | ||
|   | da1a7709fa | ||
|   | 3ab5a28edf | ||
|   | 345487e3fc | ||
|   | 3511a5c094 | ||
|   | f0d9faa705 | ||
|   | f85f7dcf8f | ||
|   | d4dd950d16 | ||
|   | 523abd3639 | ||
|   | b160702ccb | ||
|   | 80ee4dd2d4 | ||
|   | 7f23720f1b | ||
|   | 011d9d9993 | ||
|   | f538a2c7c8 | ||
|   | 86da4c1e02 | ||
|   | 36f029f5be | ||
|   | c1c1fcf494 | ||
|   | d727cbf79d | ||
|   | d242ca3749 | ||
|   | b6e8b01023 | ||
|   | f58740ad7f | ||
|   | 97561641dd | ||
|   | 3bd62a0231 | ||
|   | 7ecbb0290d | ||
|   | 7b2f12e364 | ||
|   | 90a06daa4f | ||
|   | 045e702227 | ||
|   | 22e9a5e990 | ||
|   | 50311abc2e | ||
|   | 84bf23d740 | ||
|   | 750830247a | ||
|   | 5669d1f258 | ||
|   | b7a1067528 | ||
|   | 95a21ab2f2 | ||
|   | 9392744593 | ||
|   | 74e69302d4 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 757729d145 | ||
|   | 730a422532 | ||
|   | d48215273f | ||
|   | bade01ca68 | ||
|   | 2658214018 | ||
|   | ec03ced668 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | f8a3df77bd | ||
|   | e453cb4211 | ||
|   | 0b91130e75 | ||
|   | 51ecce67e9 | ||
|   | 57e1717521 | ||
|   | 5c1d6ced8f | ||
|   | 786756a3dc | ||
|   | 05353aca85 | ||
|   | 81c2abd931 | ||
|   | 2095aa5a52 | ||
|   | ecce11a009 | ||
|   | ba3b4b5c3a | ||
|   | bb81287173 | ||
|   | e89f324c6a | ||
|   | 7dbe38e80c | ||
| 4d2a21cf0f | |||
| 42dd2c57a4 | |||
|   | 7f7a7c2dd7 | ||
|   | 1a900cda46 | ||
| 10231ee0aa | |||
|   | 9b5446c7be | ||
|   | 3390d27ba9 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 7367add2a6 | ||
| 108aae831c | |||
| 246fb81eb2 | |||
| 12ae9ae8ce | |||
| c2059a392b | |||
| ef9e236b2b | |||
|   | c4f1e269c8 | ||
|   | fcd366af2a | ||
| 7f1ce148bf | |||
| a52770e1c0 | |||
|   | f6a25a7dd4 | ||
|   | 4a25c635ee | ||
| a29c443a48 | |||
|   | 6f27a0e849 | ||
|   | 4f20378555 | ||
|   | 072e087487 | ||
| 547ed4c728 | |||
|   | bbca7bcbab | ||
| 0b70d8689d | |||
|   | 4a448189c6 | ||
|   | 58343b1dd9 | ||
|   | 8b1d9cd9b6 | ||
|   | c38c185efe | ||
|   | b5f4773923 | ||
|   | 5ff8b083d4 | ||
|   | 2635aabed7 | ||
|   | f335a7e5d2 | ||
|   | ba20357cda | ||
|   | 641f80db99 | ||
|   | 9bb70d2e6b | ||
|   | 631b2d2e14 | ||
|   | f7a55480fb | ||
|   | 0a5286832d | ||
|   | e0c11ad21c | ||
|   | ef3986de9d | ||
|   | bbe9531d05 | ||
|   | 0e7da2af19 | ||
|   | 03649e16f7 | ||
|   | 9e0b8843d3 | ||
|   | 39e7f02309 | ||
|   | ad19e1de9c | ||
|   | 4bd402c1c7 | ||
| d14f33d442 | |||
|   | 4d6a57689a | ||
|   | c438cac4e8 | ||
| ca9e725d0a | |||
|   | aba833d617 | ||
|   | b5cc57267e | ||
| 718b915991 | |||
| 2d36716977 | |||
| 6d7bacd22a | |||
| a3f33c2ea0 | |||
|   | d66ee4ab60 | ||
|   | abd2fa0ff0 | ||
|   | 9af610ef9e | ||
|   | 75a37bd07f | ||
| 6cbbfe1cde | |||
|   | a3e87e1d47 | ||
|   | 8b30b59ab4 | ||
|   | 3b74b60401 | ||
|   | 6f3ffca705 | ||
|   | c6bf2dcf3e | ||
|   | 9b8d855641 | ||
|   | 68928f71eb | ||
|   | 1c8fcd812c | ||
|   | 7c1a693dec | ||
| fa8e48aa43 | |||
|   | 396a220960 | ||
|   | 7b24cd39b6 | ||
|   | 185af90a16 | ||
|   | b2f6e52ae8 | ||
|   | fa835f8b35 | ||
|   | a86c4b6517 | ||
|   | ba1817deb7 | ||
|   | e8db5ce8af | ||
|   | 0a2cc8aa81 | ||
|   | d2d73c63c4 | ||
|   | 72fe29ef70 | ||
|   | d687b114c9 | ||
|   | 4cec0a0c94 | ||
|   | 48a328b022 | ||
|   | 01245acdb2 | ||
|   | 58206b76f2 | ||
|   | 5eea29d0ce | ||
|   | 3810c7e28e | ||
|   | ce619b6e6a | ||
|   | 7587dcb2a6 | ||
|   | e05326e07a | ||
|   | b2cfa819ae | ||
|   | c0edc33898 | ||
|   | 7ceaa9822c | ||
|   | b3004d9008 | ||
|   | 06e7dbf3f4 | ||
|   | fc338ea696 | ||
|   | 6b760d27d0 | ||
|   | 3d90fcc7e5 | ||
|   | df57b8c4e6 | ||
|   | 1d764d03f7 | ||
|   | e78fb0d387 | ||
|   | 70c7b614c1 | ||
|   | cd4ce7b55e | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | f2a7710aed | ||
|   | 5eaceb9a8e | ||
| f9d8426174 | |||
| 6ee7c34951 | |||
|   | cb498b015e | ||
| bfb5c88e79 | |||
|   | d318a6abb0 | ||
|   | 238fe7a365 | ||
| ![imgbot[bot]](/assets/img/avatar_default.png)  | c32a64e05c | ||
|   | b179d0e09e | ||
|   | b16f4869d6 | ||
|   | a846da33ad | ||
|   | 6c044312c2 | ||
|   | 8a498988e7 | ||
|   | 0d781d327b | ||
|   | 8173006301 | ||
|   | ed0430bc3a | ||
| 137a553ace | |||
|   | cebf65a89b | ||
| f34576d18a | |||
|   | ffe674124e | ||
| 57f497df54 | |||
| ab8cabf8e0 | |||
| c01b285fe4 | |||
|   | 45a5a5d2ca | ||
| 79537bf1b3 | |||
| 967882b0b7 | |||
| ec9ee8fbc3 | |||
|   | 44f7b7edd8 | ||
|   | 9d48a93a76 | ||
| b295c24a18 | |||
| a80a1aa9ac | |||
| e4654a71eb | |||
|   | c1a4eec75e | ||
|   | f5775be4be | ||
|   | 48ca20b104 | ||
|   | 77de2ba46f | ||
|   | b7916aa0f1 | ||
|   | 95845ea5e1 | ||
|   | 656eeaaab5 | ||
|   | 269e9323df | ||
| 7ba8db2287 | |||
| 8bfa10b6e4 | |||
|   | b9797310ab | ||
|   | 686e9b7bcf | ||
|   | c7e207b934 | ||
|   | 40d85c7120 | ||
|   | ea5a202af4 | ||
| e151d96dd9 | |||
|   | afa81ce50a | ||
|   | 0fbc894173 | ||
|   | e6f5b7456e | ||
| 42a301e763 | |||
| 13210d90bc | |||
| 6c297d4f77 | |||
| 669311205f | |||
| 0f4a35d003 | |||
|   | 8aacb15e21 | ||
| c62de5d29f | |||
|   | fce88ba49a | ||
|   | 25d0374939 | ||
|   | 4dfed7d77d | ||
|   | 073e904954 | ||
| 9c0f39f19d | |||
| e5b494ecb8 | |||
|   | ca24eb6ba5 | ||
| b88beee846 | |||
| 33dc6b1211 | |||
| 313696132a | |||
| 480e7d5978 | |||
|   | 945744e5e9 | ||
|   | fb8c62fc9c | ||
|   | c8bd1533d8 | ||
| ba59882e94 | |||
|   | 07a4a3009d | ||
| 8591a1afc1 | |||
|   | 0be5f75da0 | ||
| 82a251ba35 | |||
| 1dbbabd570 | |||
| ac8b551d4a | |||
| e1e18378ed | |||
| 35ec0bf432 | |||
| 40e005c517 | |||
| 504d54e7b2 | |||
| 97640d4f70 | |||
|   | a4298c0992 | ||
|   | 4ea12e8831 | ||
| 23d72ffc43 | |||
| 46d646bd5b | |||
| e5879a60f5 | |||
| bbb7ff3a43 | |||
|   | 396adfb3a8 | ||
|   | 629db03c02 | ||
| 52b7c1af6a | |||
|   | 296a5b6404 | ||
|   | ee70136f42 | ||
|   | 2c0c7fdf7e | ||
|   | 994efbb991 | ||
|   | ea81e5fa0e | ||
| d1f9813c3b | |||
|   | 95ae693dd0 | ||
|   | 96f98f4908 | ||
|   | 8df2ebed45 | ||
|   | 99c6845c98 | ||
|   | 62713d50d3 | ||
|   | 14aaaefd69 | ||
|   | 84b507b2ae | ||
|   | 4582bbfc64 | ||
|   | f59c3ba228 | ||
|   | 8e903c59f6 | ||
|   | ff5b3ee504 | ||
| 74c61e2e84 | |||
|   | e43acf1bdc | ||
|   | 0e2fba583f | ||
|   | da1407eb48 | ||
| 002aec543f | |||
| 569df8a18f | |||
| 28a5f9b2a4 | |||
| d2c9864497 | |||
|   | e4311b2689 | ||
| b9e0058739 | |||
|   | 4556849ec8 | ||
|   | 779ae1e61a | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | e340ed095c | ||
| e812c17394 | |||
| 39daf99deb | |||
|   | 74f852d2f4 | ||
| 2fdb3c5f88 | |||
|   | 214ed8e876 | ||
| a379164f87 | |||
| e39f063568 | |||
|   | 7f71093e33 | ||
|   | bd6ef18a5b | ||
|   | 00a13b8fb2 | ||
|   | 987cffd998 | ||
|   | f8a6732b38 | ||
| cd08f12848 | |||
|   | 9bdc882abd | ||
|   | 9137cb9d06 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | f2033c9c2f | ||
| 0db05bad0a | |||
| be558ebfd6 | |||
| 4ae2e9453c | |||
| 834d30ac8c | |||
| a1a20eeeb0 | |||
|   | eb6d634d3a | ||
|   | d87bb6b0de | ||
|   | 8f45e51a9e | ||
|   | fb6503a200 | ||
|   | 41beef9fae | ||
|   | 1beaa6c2b7 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 8d64d97d82 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | ee4c683e1a | ||
|   | 65a4dbbf37 | ||
|   | 4b28596983 | ||
|   | 90292634a8 | ||
|   | f6a176b30c | ||
|   | 6673523a71 | ||
|   | ce85dc9bf9 | ||
|   | f7bbd36aef | ||
|   | e156345ecf | ||
|   | c2c8d6fba1 | ||
|   | aa63bb7378 | ||
|   | b028b389a9 | ||
|   | 24215dc880 | ||
|   | aabc5827e3 | ||
|   | 6be4ce2575 | ||
|   | 8a50bac101 | ||
|   | 0665669173 | ||
|   | 51fc9076cb | ||
|   | d185d5cdc8 | ||
|   | e37fa65be1 | ||
|   | 72ef50f914 | ||
|   | 8776541daa | ||
|   | a98a1e4c5b | ||
|   | b0dbd8330e | ||
|   | 881df3e5da | ||
|   | f8b6efb995 | ||
|   | dc94c77dad | ||
|   | 2582abe3d7 | ||
|   | 5e7dc85052 | ||
|   | 9a6e6c617d | ||
|   | 9aff2ad351 | ||
| be3febe40a | |||
| 2f726c9f4b | |||
|   | 6e14cdfadc | ||
|   | 0923783611 | ||
| 1e6485fb3c | |||
| 9df67861c9 | |||
| 4343ae6c02 | |||
| ffdb89720c | |||
| e49aa04efc | |||
|   | 7d24b5c0c1 | ||
|   | 122f21fce2 | ||
|   | 3ec675cd05 | ||
|   | 1b71db4575 | ||
|   | f7a3eaa0cb | ||
|   | 5b1f1a14f3 | ||
|   | 24d068bc27 | ||
| bca3748ca7 | |||
|   | 866e75955a | ||
|   | 5c520ab865 | ||
|   | 97e5b9ab0a | ||
|   | 799c520437 | ||
|   | e7ade0215a | ||
| 4d652b88d7 | |||
|   | 39e54ea40b | ||
| 09f07f3584 | |||
|   | 75bd0b1358 | ||
|   | 91abf0f412 | ||
|   | b2e81cf9bd | ||
|   | cbb82a2399 | ||
|   | 16dc6c6d34 | ||
|   | 55a4058ef4 | ||
|   | 43dc5a9b3e | ||
|   | 90d36575c4 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | c22743c1c9 | ||
|   | 9ad644ee37 | ||
|   | b1dffdc3e8 | ||
|   | d19deee5a5 | ||
|   | d9aff3d770 | ||
|   | 0a7f85ceeb | ||
|   | cc13fb189c | ||
|   | c237e5595e | ||
|   | 38a948d30d | ||
|   | f8c574d856 | ||
| 46aa2088e5 | |||
|   | 929b942a4d | ||
|   | b6d24a79ee | ||
|   | b6cd39a22d | ||
|   | c85098f4c3 | ||
|   | de909e61fd | ||
|   | a8216603f4 | ||
|   | 28d7c1b3c0 | ||
|   | 325f511234 | ||
|   | 363d87a38a | ||
|   | 029bf2bbbd | ||
|   | 140cc62b5a | ||
|   | fec526192b | ||
|   | 3ff77e729f | 
							
								
								
									
										1
									
								
								.allowed_signers
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1 @@ | ||||
| jonah@privacyguides.org ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIJUp+Gi8ZpTDDbZC+GY+3QnFfxkI9rAu07bceyoHDp9O | ||||
							
								
								
									
										8
									
								
								.devcontainer/devcontainer.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,8 @@ | ||||
| // For format details, see https://aka.ms/devcontainer.json. For config options, see the | ||||
| // README at: https://github.com/devcontainers/templates/tree/main/src/python | ||||
| { | ||||
| 	"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" | ||||
| } | ||||
							
								
								
									
										8
									
								
								.devcontainer/team/devcontainer.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,8 @@ | ||||
| // For format details, see https://aka.ms/devcontainer.json. For config options, see the | ||||
| // README at: https://github.com/devcontainers/templates/tree/main/src/python | ||||
| { | ||||
| 	"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" | ||||
| } | ||||
							
								
								
									
										38
									
								
								.editorconfig
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,38 @@ | ||||
| # 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. | ||||
|  | ||||
| # EditorConfig is awesome: https://EditorConfig.org | ||||
|  | ||||
| # top-most EditorConfig file | ||||
| root = true | ||||
|  | ||||
| # Unix-style newlines with a newline ending every file | ||||
| [*] | ||||
| charset = utf-8 | ||||
| indent_style = space | ||||
| indent_size = 2 | ||||
| end_of_line = lf | ||||
| insert_final_newline = true | ||||
| trim_trailing_whitespace = true | ||||
|  | ||||
| [{*.caddy,*.example-caddy,Caddyfile}] | ||||
| charset = utf-8 | ||||
| indent_style = tab | ||||
| tab_width = 4 | ||||
							
								
								
									
										32
									
								
								.gitattributes
									
									
									
									
										vendored
									
									
								
							
							
						
						| @@ -1,2 +1,34 @@ | ||||
| # Copyright (c) 2020-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. | ||||
|  | ||||
| # Auto detect text files and perform LF normalization | ||||
| * text=auto | ||||
|  | ||||
| docs/** -linguist-documentation | ||||
| .git* text | ||||
| *.json text | ||||
| *.js text | ||||
| *.md text linguist-detectable | ||||
| *.{yml,yaml} text | ||||
| *.{htm,html} text diff=html | ||||
|  | ||||
| *.svg text | ||||
| *.png binary | ||||
| *.{jpeg,jpg} binary | ||||
|   | ||||
							
								
								
									
										28
									
								
								.github/CODEOWNERS
									
									
									
									
										vendored
									
									
								
							
							
						
						| @@ -1,21 +1,15 @@ | ||||
| # Additional Co-Owners are added to the TOP of this file. | ||||
|  | ||||
| # High-traffic pages | ||||
| /index.html @JonahAragon @dngray | ||||
| /blog.html @JonahAragon | ||||
| /docs/index.md @jonaharagon @dngray | ||||
| /theme/overrides/ @jonaharagon | ||||
|  | ||||
| # Org/legal | ||||
| /notices.md @JonahAragon | ||||
| /privacy-policy.md @JonahAragon | ||||
| LICENSE @JonahAragon | ||||
|  | ||||
| # Website dev | ||||
| /_sass/ @JonahAragon | ||||
| /_layouts/ @JonahAragon | ||||
| Gemfile @JonahAragon | ||||
| Gemfile.lock @JonahAragon | ||||
| _config.yml @JonahAragon | ||||
| # Org | ||||
| /docs/about/ @jonaharagon | ||||
| CODE_OF_CONDUCT.md @jonaharagon | ||||
| CITATION.cff | ||||
| LICENSE @jonaharagon | ||||
| README.md @jonaharagon @dngray | ||||
|  | ||||
| # Ops | ||||
| /.github/ @JonahAragon | ||||
| /.well-known/ @JonahAragon | ||||
| /Pipfile @jonaharagon | ||||
| /Pipfile.lock @jonaharagon | ||||
| /.github/ @jonaharagon | ||||
|   | ||||
| @@ -1,8 +0,0 @@ | ||||
| --- | ||||
| name: "Content Correction" | ||||
| about: Report any inaccurate, incorrect, or outdated information on the website. | ||||
| --- | ||||
|  | ||||
| ## Description | ||||
|  | ||||
| **URL of affected page:** | ||||
							
								
								
									
										65
									
								
								.github/ISSUE_TEMPLATE/1_Content_Correction.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,65 @@ | ||||
| # Copyright (c) 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. | ||||
|  | ||||
| name: "Content Correction" | ||||
| description: Report any inaccurate, incorrect, or outdated information on the website. | ||||
| labels: ["t:correction"] | ||||
| body: | ||||
|   - type: markdown | ||||
|     attributes: | ||||
|       value: | | ||||
|         This form is for reporting verifiable issues with our website. | ||||
|         If you simply disagree with an opinion on the website, please open a discussion [on our forum](https://discuss.privacyguides.net) instead. | ||||
|  | ||||
|   - type: input | ||||
|     attributes: | ||||
|       label: Affected page | ||||
|       description: Please let us know which page the incorrect information can be found on. | ||||
|       placeholder: "https://www.privacyguides.org/en/data-redaction" | ||||
|     validations: | ||||
|       required: true | ||||
|  | ||||
|   - type: textarea | ||||
|     id: description | ||||
|     attributes: | ||||
|       label: Description | ||||
|       description: Please let us know what should be fixed. | ||||
|       placeholder: The Google Play Store link for ExifEraser is broken... | ||||
|     validations: | ||||
|       required: true | ||||
|  | ||||
|   - type: textarea | ||||
|     id: source | ||||
|     attributes: | ||||
|       label: Sources | ||||
|       description: Please provide reliable sources that support the change you are requesting. | ||||
|     validations: | ||||
|       required: true | ||||
|  | ||||
|   - type: checkboxes | ||||
|     id: checklist | ||||
|     attributes: | ||||
|       label: Before submitting | ||||
|       description: The Code of Conduct helps create a safe space for everyone. We require that everyone agrees to it. | ||||
|       options: | ||||
|         - label: I am reporting something that is verifiably incorrect, not a suggestion or opinion. | ||||
|           required: true | ||||
|         - label: I agree to the [Community Code of Conduct](https://www.privacyguides.org/coc). | ||||
|           required: true | ||||
							
								
								
									
										22
									
								
								.github/ISSUE_TEMPLATE/2_Website_Issues.md
									
									
									
									
										vendored
									
									
								
							
							
						
						| @@ -1,22 +0,0 @@ | ||||
| --- | ||||
| name: "Website Issue" | ||||
| about: Report a bug with the website. (NO CONTENT ISSUES) | ||||
| title: "Website Issue | " | ||||
| --- | ||||
|  | ||||
| <!-- | ||||
|  | ||||
| READ ME FIRST: | ||||
| This is NOT the place to request changes to the content of the website. | ||||
| This is NOT the place to report issues with our services like Matrix. | ||||
| This is ONLY for reporting bugs or technical issues with www.privacyguides.org, the website. | ||||
|  | ||||
| --> | ||||
|  | ||||
| ## Description | ||||
|  | ||||
| <!-- | ||||
| ## Screenshots | ||||
|  | ||||
| Please add screenshots if applicable | ||||
| --> | ||||
							
								
								
									
										100
									
								
								.github/ISSUE_TEMPLATE/2_Website_Issues.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,100 @@ | ||||
| # Copyright (c) 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. | ||||
|  | ||||
| name: "Website Issue" | ||||
| description: Report a bug with the website. | ||||
| labels: ["t:bug"] | ||||
| assignees: | ||||
|   - jonaharagon | ||||
| body: | ||||
|   - type: markdown | ||||
|     attributes: | ||||
|       value: | | ||||
|         This form is only for reporting a technical bug __with our website__, like broken images, broken CSS, issues with search or themes, etc. | ||||
|         This is not the place to report an issue with Matrix, Discourse, or our other hosted services. | ||||
|  | ||||
|         If you want us to fix inaccurate information on the website, go back and use the content correction form. | ||||
|         If you want to make another suggestion, please [use our discussion forum](https://discuss.privacyguides.net) instead. | ||||
|  | ||||
|   - type: textarea | ||||
|     id: description | ||||
|     attributes: | ||||
|       label: Bug description | ||||
|       description: | | ||||
|         Please give a detailed description of the bug. | ||||
|         Explain how the website does not behave as you would expect it to, and be as specific as possible. | ||||
|         If you have found a workaround or a fix for the problem too, please let us know. | ||||
|     validations: | ||||
|       required: true | ||||
|  | ||||
|   - type: textarea | ||||
|     id: affected-pages | ||||
|     attributes: | ||||
|       label: Affected pages | ||||
|       description: | | ||||
|         Please list all pages where you've noticed this issue, or let us know if it affects every page on the site. | ||||
|       value: | | ||||
|         - | ||||
|  | ||||
|   - type: dropdown | ||||
|     id: browser | ||||
|     attributes: | ||||
|       label: Browser | ||||
|       description: | | ||||
|         Please select the browser(s) you have noticed this issue with. | ||||
|         If your browser is not listed or the version is relevant, you may select _Other_ and provide more details in the description above. | ||||
|       multiple: true | ||||
|       options: | ||||
|         - Firefox | ||||
|         - Tor Browser | ||||
|         - Chrome | ||||
|         - Safari | ||||
|         - Edge | ||||
|         - Other | ||||
|  | ||||
|   - type: dropdown | ||||
|     id: os | ||||
|     attributes: | ||||
|       label: Operating System | ||||
|       description: | | ||||
|         Please select the operating system(s) you have noticed this issue with. | ||||
|       multiple: true | ||||
|       options: | ||||
|         - Linux | ||||
|         - macOS | ||||
|         - Windows | ||||
|         - Android | ||||
|         - iOS | ||||
|         - Other | ||||
|  | ||||
|   - type: checkboxes | ||||
|     id: checklist | ||||
|     attributes: | ||||
|       label: Before submitting | ||||
|       description: The Code of Conduct helps create a safe space for everyone. We require that everyone agrees to it. | ||||
|       options: | ||||
|         - label: I am reporting something that is broken on the website, not making a suggestion. | ||||
|           required: true | ||||
|         - label: I agree to the [Community Code of Conduct](https://www.privacyguides.org/coc). | ||||
|           required: true | ||||
|  | ||||
|   - type: markdown | ||||
|     attributes: | ||||
|       value: Thank you for letting us know about this! | ||||
							
								
								
									
										34
									
								
								.github/ISSUE_TEMPLATE/config.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						| @@ -1,11 +1,37 @@ | ||||
| # Copyright (c) 2020-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. | ||||
|  | ||||
| blank_issues_enabled: false | ||||
| contact_links: | ||||
|   - name: Suggest a New Provider or Software | ||||
|     url: https://github.com/privacyguides/privacyguides.org/discussions/new | ||||
|   - name: Suggest Adding or Removing a Tool | ||||
|     url: https://discuss.privacyguides.net/c/site-development/suggestions | ||||
|     about: Suggest something new for us to look at, or something we should remove. | ||||
|   - name: Suggest a New Guide | ||||
|     url: https://discuss.privacyguides.net/c/site-development/guide-suggestions | ||||
|     about: Suggest an area where you think guidance might be required. | ||||
|   - name: Ask a Question | ||||
|     url: https://github.com/privacyguides/privacyguides.org/discussions/new | ||||
|     url: https://discuss.privacyguides.net/c/privacy/questions | ||||
|     about: Let us know if something doesn't make sense! | ||||
|   - name: Share an Idea | ||||
|     url: https://github.com/privacyguides/privacyguides.org/discussions/new | ||||
|     url: https://discuss.privacyguides.net/c/site-development | ||||
|     about: Suggest a new feature/section/page or anything else for the website. | ||||
|   - name: Report a Translation Issue | ||||
|     url: https://crowdin.com/project/privacyguides/discussions | ||||
|     about: Please report an issue with website translations on Crowdin. | ||||
|   | ||||
							
								
								
									
										32
									
								
								.github/PULL_REQUEST_TEMPLATE.md
									
									
									
									
										vendored
									
									
								
							
							
						
						| @@ -1,24 +1,24 @@ | ||||
| <!-- Submitting a PR? Awesome!! --> | ||||
| Changes proposed in this PR: | ||||
|  | ||||
| ## Description | ||||
| - | ||||
|  | ||||
| Resolves: # <!-- Did you solve an open GitHub issue? Put the number here so we mark it complete! --> | ||||
|  | ||||
| <!-- | ||||
| Please share with us what you've changed. | ||||
| If you are adding a software recommendation, give us a link to its website or | ||||
| source code. | ||||
| <!-- 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 | ||||
| disclose this as well: | ||||
| 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. | ||||
|  | ||||
| That someone has a conflict of interest is a description of a situation, | ||||
| NOT a judgement about that person's opinions, integrity, or good faith. | ||||
|  | ||||
| If you have a conflict of interest, you must disclose who is paying you for | ||||
| this contribution, who the client is (if for example, you are being paid by | ||||
| an advertising agency), and any other relevant affiliations. | ||||
| --> | ||||
|  | ||||
| <!-- 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. --> | ||||
|   | ||||
							
								
								
									
										80
									
								
								.github/dependabot.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						| @@ -1,27 +1,77 @@ | ||||
| # 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: | ||||
|  | ||||
|   fortawesome: | ||||
|     type: npm-registry | ||||
|     url: https://npm.fontawesome.com/ | ||||
|     token: ${{ secrets.FONTAWESOME_NPM_AUTH_TOKEN }} | ||||
|   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: "daily" | ||||
|       interval: "monthly" | ||||
|     assignees: | ||||
|       - "jonaharagon" | ||||
|     reviewers: | ||||
|       - "jonaharagon" | ||||
|     labels: | ||||
|       - "fix:github_actions" | ||||
|  | ||||
|   - package-ecosystem: "bundler" # See documentation for possible values | ||||
|     directory: "/" # Location of package manifests | ||||
|     schedule: | ||||
|       interval: "daily" | ||||
|  | ||||
|   - package-ecosystem: "npm" | ||||
|   # Maintain submodules | ||||
|   - package-ecosystem: "gitsubmodule" | ||||
|     directory: "/" | ||||
|     registries: | ||||
|       - fortawesome | ||||
|       - github-privacyguides | ||||
|     schedule: | ||||
|       interval: "daily" | ||||
|       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" | ||||
|   | ||||
							
								
								
									
										93
									
								
								.github/workflows/build-container.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,93 @@ | ||||
| # | ||||
| name: ☁️ Build Container | ||||
|  | ||||
| # Configures this workflow to run every time a change is pushed to the branch called `release`. | ||||
| on: | ||||
|   push: | ||||
|     branches: ['main'] | ||||
|   release: | ||||
|     types: [published] | ||||
|   workflow_dispatch: | ||||
|  | ||||
| concurrency: | ||||
|   group: container-build | ||||
|   cancel-in-progress: true | ||||
|  | ||||
| permissions: | ||||
|   contents: read | ||||
|   packages: write | ||||
|  | ||||
| # Defines two custom environment variables for the workflow. These are used for the Container registry domain, and a name for the Docker image that this workflow builds. | ||||
| env: | ||||
|   REGISTRY: ghcr.io | ||||
|   IMAGE_NAME: ${{ github.repository }} | ||||
|  | ||||
| # There is a single job in this workflow. It's configured to run on the latest available version of Ubuntu. | ||||
| jobs: | ||||
|   submodule: | ||||
|     strategy: | ||||
|       matrix: | ||||
|         repo: [mkdocs-material-insiders, brand] | ||||
|     uses: privacyguides/.github/.github/workflows/download-repo.yml@main | ||||
|     with: | ||||
|       repo: ${{ matrix.repo }} | ||||
|     secrets: | ||||
|       ACTIONS_SSH_KEY: ${{ secrets.ACTIONS_SSH_KEY }} | ||||
|  | ||||
|   build-and-push-image: | ||||
|     needs: submodule | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|       - name: Checkout repository | ||||
|         uses: actions/checkout@v4 | ||||
|         with: | ||||
|           fetch-depth: 0 | ||||
|  | ||||
|       - uses: actions/download-artifact@v4 | ||||
|         with: | ||||
|           pattern: repo-* | ||||
|           path: modules | ||||
|  | ||||
|       - run: | | ||||
|           rm -rf modules/mkdocs-material | ||||
|           mv modules/repo-mkdocs-material-insiders modules/mkdocs-material | ||||
|           rm -rf theme/assets/brand | ||||
|           mv modules/repo-brand theme/assets/brand | ||||
|  | ||||
|       # 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 | ||||
|         with: | ||||
|           registry: ${{ env.REGISTRY }} | ||||
|           username: ${{ github.actor }} | ||||
|           password: ${{ secrets.GITHUB_TOKEN }} | ||||
|  | ||||
|       # This step uses [docker/metadata-action](https://github.com/docker/metadata-action#about) to extract tags and labels that will be applied to the specified image. The `id` "meta" allows the output of this step to be referenced in a subsequent step. The `images` value provides the base name for the tags and labels. | ||||
|       - name: Extract metadata (tags, labels) for Docker | ||||
|         id: meta | ||||
|         uses: docker/metadata-action@v5.5.1 | ||||
|         with: | ||||
|           images: ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }} | ||||
|           tags: | | ||||
|             type=ref,event=branch | ||||
|             type=ref,event=tag | ||||
|             type=ref,event=pr | ||||
|             type=sha | ||||
|           flavor: | | ||||
|             latest=${{ github.event_name == 'release' }} | ||||
|  | ||||
|       # This step uses the `docker/build-push-action` action to build the image, based on your repository's `Dockerfile`. If the build succeeds, it pushes the image to GitHub Packages. | ||||
|       # 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 | ||||
|         with: | ||||
|           context: . | ||||
|           push: true | ||||
|           tags: ${{ steps.meta.outputs.tags }} | ||||
|           labels: ${{ steps.meta.outputs.labels }} | ||||
|  | ||||
|   cleanup: | ||||
|     if: ${{ always() }} | ||||
|     needs: build-and-push-image | ||||
|     uses: privacyguides/.github/.github/workflows/cleanup.yml@main | ||||
							
								
								
									
										189
									
								
								.github/workflows/build.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						| @@ -1,46 +1,171 @@ | ||||
| name: Build Website | ||||
| on: | ||||
|   pull_request: | ||||
|     branches: | ||||
|       - main | ||||
|  | ||||
| env: | ||||
|   PYTHON_VERSION: 3.x | ||||
| on: | ||||
|   workflow_call: | ||||
|     inputs: | ||||
|       config: | ||||
|         type: string | ||||
|         default: build | ||||
|       ref: | ||||
|         required: true | ||||
|         type: string | ||||
|       repo: | ||||
|         required: true | ||||
|         type: string | ||||
|       lang: | ||||
|         type: string | ||||
|         default: en | ||||
|       context: | ||||
|         type: string | ||||
|         default: deploy-preview | ||||
|       continue-on-error: | ||||
|         type: boolean | ||||
|         default: true | ||||
|  | ||||
| permissions: | ||||
|   contents: read | ||||
|  | ||||
| jobs: | ||||
|   build: | ||||
|     name: Build website | ||||
|     runs-on: ubuntu-latest | ||||
|     continue-on-error: ${{ inputs.continue-on-error }} | ||||
|     permissions: | ||||
|       contents: read | ||||
|  | ||||
|     steps: | ||||
|       - run: | | ||||
|           echo "GH_TOKEN=${{ secrets.GITHUB_TOKEN }}" >> $GITHUB_ENV | ||||
|  | ||||
|       - name: Checkout repository | ||||
|         uses: actions/checkout@v3 | ||||
|       - if: inputs.config == 'build' | ||||
|         run: | | ||||
|           echo "MKDOCS_INHERIT=mkdocs-production.yml" >> $GITHUB_ENV | ||||
|           echo "PRODUCTION=true" >> $GITHUB_ENV | ||||
|           echo "CONTEXT=${{ inputs.context }}" >> $GITHUB_ENV | ||||
|  | ||||
|       - name: Set up Python runtime | ||||
|         uses: actions/setup-python@v3 | ||||
|       - if: inputs.config == 'offline' | ||||
|         run: | | ||||
|           echo "MKDOCS_INHERIT=mkdocs-offline.yml" >> $GITHUB_ENV | ||||
|           echo "CARDS=false" >> $GITHUB_ENV | ||||
|  | ||||
|       - uses: actions/checkout@v4 | ||||
|         with: | ||||
|           python-version: ${{ env.PYTHON_VERSION }} | ||||
|        | ||||
|       - name: Cache files | ||||
|         uses: actions/cache@v2 | ||||
|           repository: ${{ inputs.repo }} | ||||
|           ref: ${{ inputs.ref }} | ||||
|           persist-credentials: "false" | ||||
|           fetch-depth: 0 | ||||
|  | ||||
|       - uses: actions/download-artifact@v4 | ||||
|         with: | ||||
|           key: ${{ github.ref }} | ||||
|           pattern: repo-* | ||||
|           path: modules | ||||
|  | ||||
|       - run: | | ||||
|           rmdir modules/mkdocs-material | ||||
|           mv modules/repo-mkdocs-material-insiders modules/mkdocs-material | ||||
|           rmdir theme/assets/brand | ||||
|           mv modules/repo-brand theme/assets/brand | ||||
|  | ||||
|       - 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 | ||||
|         with: | ||||
|           cache: "pipenv" | ||||
|  | ||||
|       - uses: actions/cache/restore@v4.0.2 | ||||
|         with: | ||||
|           key: site-cache-${{ inputs.repo }}-${{ inputs.ref }}-${{ hashfiles('.cache/**') }} | ||||
|           path: .cache | ||||
|           restore-keys: | | ||||
|             site-cache-${{ inputs.repo }}-${{ inputs.ref }}- | ||||
|             site-cache-${{ inputs.repo }}- | ||||
|  | ||||
|       - uses: actions/cache/restore@v4.0.2 | ||||
|         with: | ||||
|           key: card-cache-${{ inputs.repo }}-${{ inputs.lang }}-${{ inputs.ref }}-${{ hashfiles('config/.cache/plugin/social/manifest.json') }} | ||||
|           path: | | ||||
|             config/.cache/plugin/social/manifest.json | ||||
|             config/.cache/plugin/social/assets | ||||
|           restore-keys: | | ||||
|             card-cache-${{ inputs.repo }}-${{ inputs.lang }}-${{ inputs.ref }}- | ||||
|             card-cache-${{ inputs.repo }}-${{ inputs.lang }}- | ||||
|  | ||||
|       - 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 | ||||
|  | ||||
|       - 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 | ||||
|  | ||||
|       - uses: actions/cache/save@v4.0.2 | ||||
|         with: | ||||
|           key: site-cache-${{ inputs.repo }}-${{ inputs.ref }}-${{ hashfiles('.cache/**') }} | ||||
|           path: .cache | ||||
|  | ||||
|       - name: Install Python dependencies | ||||
|         run: | | ||||
|           pip install mkdocs | ||||
|           pip install mkdocs-material | ||||
|  | ||||
|       - name: Build website | ||||
|         run: | | ||||
|           mkdocs build | ||||
|           mv .well-known site/ | ||||
|           tar cvf site.tar site | ||||
|           mkdocs --version | ||||
|  | ||||
|       - name: Package website | ||||
|         uses: actions/upload-artifact@v2 | ||||
|       - uses: actions/cache/save@v4.0.2 | ||||
|         with: | ||||
|           name: generated-site | ||||
|           path: site.tar | ||||
|           key: card-cache-${{ inputs.repo }}-${{ inputs.lang }}-${{ inputs.ref }}-${{ hashfiles('config/.cache/plugin/social/manifest.json') }} | ||||
|           path: | | ||||
|             config/.cache/plugin/social/manifest.json | ||||
|             config/.cache/plugin/social/assets | ||||
|  | ||||
|       - uses: actions/upload-artifact@v4 | ||||
|         with: | ||||
|           name: site-${{ inputs.config }}-${{ inputs.lang }}.tar.gz | ||||
|           path: site-${{ inputs.config }}-${{ inputs.lang }}.tar.gz | ||||
|  | ||||
|   offline_package: | ||||
|     if: inputs.config == 'offline' && inputs.lang == 'en' | ||||
|     needs: build | ||||
|     runs-on: ubuntu-latest | ||||
|     continue-on-error: ${{ inputs.continue-on-error }} | ||||
|     permissions: | ||||
|       contents: read | ||||
|  | ||||
|     steps: | ||||
|       - uses: actions/download-artifact@v4 | ||||
|         with: | ||||
|           name: site-offline-en.tar.gz | ||||
|  | ||||
|       - run: | | ||||
|           tar -xzvf site-offline-en.tar.gz | ||||
|           tar -czvf offline.tar.gz site/en | ||||
|           zip -r -q offline.zip site/en | ||||
|  | ||||
|       - name: Upload tar.gz file | ||||
|         uses: actions/upload-artifact@v4 | ||||
|         with: | ||||
|           name: offline.tar.gz | ||||
|           path: offline.tar.gz | ||||
|  | ||||
|       - name: Upload zip file | ||||
|         uses: actions/upload-artifact@v4 | ||||
|         with: | ||||
|           name: offline.zip | ||||
|           path: offline.zip | ||||
|  | ||||
|       - name: Create ZIM File | ||||
|         uses: addnab/docker-run-action@v3 | ||||
|         with: | ||||
|           image: ghcr.io/openzim/zim-tools:3.1.3 | ||||
|           options: -v ${{ github.workspace }}:/data | ||||
|           run: | | ||||
|             zimwriterfs -w index.html -I assets/brand/logos/png/square/pg-yellow.png -l eng -t "Privacy Guides" -d "Your central privacy and security resource to protect yourself online." -c "Privacy Guides" -p "Jonah Aragon" -n "Privacy Guides" -e "https://github.com/privacyguides/privacyguides.org" /data/site/en /data/offline-privacy_guides.zim | ||||
|  | ||||
|       - name: Upload ZIM file | ||||
|         uses: actions/upload-artifact@v4 | ||||
|         with: | ||||
|           name: offline-privacy_guides.zim | ||||
|           path: offline-privacy_guides.zim | ||||
|   | ||||
							
								
								
									
										73
									
								
								.github/workflows/deploy.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						| @@ -1,73 +0,0 @@ | ||||
| name: Deploy Website | ||||
| on: | ||||
|   push: | ||||
|     branches: | ||||
|       - main | ||||
|  | ||||
| env: | ||||
|   PYTHON_VERSION: 3.x | ||||
|  | ||||
| jobs: | ||||
|   build: | ||||
|     name: Build website | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|  | ||||
|       - name: Checkout repository | ||||
|         uses: actions/checkout@v3 | ||||
|  | ||||
|       - name: Set up Python runtime | ||||
|         uses: actions/setup-python@v3 | ||||
|         with: | ||||
|           python-version: ${{ env.PYTHON_VERSION }} | ||||
|        | ||||
|       - name: Cache files | ||||
|         uses: actions/cache@v2 | ||||
|         with: | ||||
|           key: ${{ github.ref }} | ||||
|           path: .cache | ||||
|  | ||||
|       - name: Install Python dependencies | ||||
|         run: | | ||||
|           pip install 'mkdocs>=1.3.0' | ||||
|  | ||||
|       - name: Install mkdocs-material Insiders build | ||||
|         if: github.event.repository.fork == false | ||||
|         env: | ||||
|           GH_TOKEN: ${{ secrets.GH_TOKEN }} | ||||
|         run: | | ||||
|           git clone --depth 1 https://${GH_TOKEN}@github.com/squidfunk/mkdocs-material-insiders.git | ||||
|           pip install -e mkdocs-material-insiders | ||||
|  | ||||
|       - name: Build website | ||||
|         run: | | ||||
|           mkdocs build --config-file mkdocs.production.yml | ||||
|           mv .well-known site/ | ||||
|           tar cvf site.tar site | ||||
|           mkdocs --version | ||||
|  | ||||
|       - name: Package website | ||||
|         uses: actions/upload-artifact@v2 | ||||
|         with: | ||||
|           name: generated-site | ||||
|           path: site.tar | ||||
|  | ||||
|   deploy: | ||||
|     name: Rsync Deploy | ||||
|     runs-on: ubuntu-latest | ||||
|     environment: production | ||||
|     needs: build | ||||
|  | ||||
|     steps: | ||||
|       - name: Download generated Jekyll site | ||||
|         uses: actions/download-artifact@v2 | ||||
|         with: | ||||
|           name: generated-site | ||||
|       - run: tar xvf site.tar | ||||
|       - name: Copy built site to production | ||||
|         run: | | ||||
|           mkdir -p ~/.ssh | ||||
|           echo "${{ secrets.SSH_KEY }}" > ~/.ssh/id_rsa | ||||
|           chmod 700 ~/.ssh/id_rsa | ||||
|           ssh-keyscan -H ${{ secrets.SSH_HOST }} >> ~/.ssh/known_hosts | ||||
|           rsync -azP --delete site/ ${{ secrets.SSH_USERNAME }}@${{ secrets.SSH_HOST }}:${{ secrets.SSH_PATH }} | ||||
							
								
								
									
										64
									
								
								.github/workflows/publish-mirror.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,64 @@ | ||||
| # Copyright (c) 2022 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: 🪞 Push to Mirrors | ||||
|  | ||||
| permissions: | ||||
|   contents: read | ||||
|  | ||||
| on: [push, delete, create] | ||||
|  | ||||
| # Ensures that only one mirror task will run at a time. | ||||
| concurrency: | ||||
|   group: git-mirror | ||||
|  | ||||
| jobs: | ||||
|   gitlab: | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|       - name: Mirror to GitLab | ||||
|         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@gitlab.com:privacyguides/privacyguides.org.git" | ||||
|  | ||||
|   codeberg: | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|       - name: Mirror to Codeberg | ||||
|         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@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" | ||||
							
								
								
									
										103
									
								
								.github/workflows/publish-pr.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,103 @@ | ||||
| # 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 | ||||
|  | ||||
| permissions: | ||||
|   pull-requests: write | ||||
|   contents: read | ||||
|  | ||||
| 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 }} | ||||
|  | ||||
|   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 | ||||
|     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_site_id: ${{ vars.NETLIFY_SITE }} | ||||
|     secrets: | ||||
|       NETLIFY_TOKEN: ${{ secrets.NETLIFY_TOKEN }} | ||||
|  | ||||
|   comment: | ||||
|     permissions: | ||||
|       pull-requests: write | ||||
|     needs: deploy | ||||
|     runs-on: ubuntu-latest | ||||
|     env: | ||||
|       address: ${{ needs.deploy.outputs.address }} | ||||
|     steps: | ||||
|       - uses: thollander/actions-comment-pull-request@v2.5.0 | ||||
|         with: | ||||
|           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> Preview | ${{ env.address }} | | ||||
|           comment_tag: deployment | ||||
|  | ||||
|   cleanup: | ||||
|     if: ${{ always() }} | ||||
|     needs: build | ||||
|     uses: privacyguides/.github/.github/workflows/cleanup.yml@main | ||||
							
								
								
									
										103
									
								
								.github/workflows/publish-release.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,103 @@ | ||||
| # Copyright (c) 2021-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: 📦 Release | ||||
|  | ||||
| on: | ||||
|   push: | ||||
|     tags: | ||||
|       - "*" | ||||
|  | ||||
| concurrency: | ||||
|   group: release-deployment | ||||
|   cancel-in-progress: true | ||||
|  | ||||
| permissions: | ||||
|   contents: write | ||||
|   pages: write | ||||
|   id-token: write | ||||
|   deployments: write | ||||
|  | ||||
| jobs: | ||||
|   submodule: | ||||
|     strategy: | ||||
|       matrix: | ||||
|         repo: [mkdocs-material-insiders, brand, i18n] | ||||
|     uses: privacyguides/.github/.github/workflows/download-repo.yml@main | ||||
|     with: | ||||
|       repo: ${{ matrix.repo }} | ||||
|     secrets: | ||||
|       ACTIONS_SSH_KEY: ${{ secrets.ACTIONS_SSH_KEY }} | ||||
|  | ||||
|   build: | ||||
|     needs: submodule | ||||
|     strategy: | ||||
|       matrix: | ||||
|         lang: [en, es, fr, he, it, nl, ru, zh-Hant] | ||||
|         build: [build, offline] | ||||
|     permissions: | ||||
|       contents: read | ||||
|     uses: ./.github/workflows/build.yml | ||||
|     with: | ||||
|       config: ${{ matrix.build }} | ||||
|       ref: ${{ github.ref }} | ||||
|       repo: ${{ github.repository }} | ||||
|       lang: ${{ matrix.lang }} | ||||
|       context: production | ||||
|       continue-on-error: false | ||||
|  | ||||
|   release: | ||||
|     name: Create release notes | ||||
|     needs: build | ||||
|     runs-on: ubuntu-latest | ||||
|     permissions: | ||||
|       contents: write | ||||
|  | ||||
|     steps: | ||||
|       - uses: actions/download-artifact@v4 | ||||
|         with: | ||||
|           pattern: offline* | ||||
|           merge-multiple: true | ||||
|  | ||||
|       - name: Create release notes | ||||
|         uses: ncipollo/release-action@v1 | ||||
|         with: | ||||
|           generateReleaseNotes: true | ||||
|           artifacts: "offline.zip,offline.tar.gz,offline-privacy_guides.zim" | ||||
|           makeLatest: true | ||||
|  | ||||
|   deploy: | ||||
|     needs: build | ||||
|     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 }} | ||||
|       CF_API_TOKEN: ${{ secrets.CF_API_TOKEN }} | ||||
|       CF_ACCOUNT_ID: ${{ secrets.CF_ACCOUNT_ID }} | ||||
|       CLUSTER_USERNAME: ${{ secrets.CLUSTER_USERNAME }} | ||||
|       CLUSTER_PASSWORD: ${{ secrets.CLUSTER_PASSWORD }} | ||||
|       CLOUDFLARE_ZONE: ${{ secrets.CLOUDFLARE_ZONE }} | ||||
|       CLOUDFLARE_TOKEN: ${{ secrets.CLOUDFLARE_TOKEN }} | ||||
|  | ||||
|   cleanup: | ||||
|     if: ${{ always() }} | ||||
|     needs: build | ||||
|     uses: privacyguides/.github/.github/workflows/cleanup.yml@main | ||||
							
								
								
									
										64
									
								
								.github/workflows/test-build.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,64 @@ | ||||
| # 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: 📦 Manual Test Build | ||||
|  | ||||
| on: | ||||
|   workflow_dispatch: | ||||
|  | ||||
| permissions: | ||||
|   contents: read | ||||
|  | ||||
| jobs: | ||||
|   submodule: | ||||
|     strategy: | ||||
|       matrix: | ||||
|         repo: [mkdocs-material-insiders, brand, i18n] | ||||
|     uses: privacyguides/.github/.github/workflows/download-repo.yml@main | ||||
|     with: | ||||
|       repo: ${{ matrix.repo }} | ||||
|     secrets: | ||||
|       ACTIONS_SSH_KEY: ${{ secrets.ACTIONS_SSH_KEY }} | ||||
|  | ||||
|   build: | ||||
|     needs: submodule | ||||
|     strategy: | ||||
|       matrix: | ||||
|         lang: [en, es, fr, he, it, nl, ru, zh-Hant] | ||||
|       fail-fast: false | ||||
|     permissions: | ||||
|       contents: read | ||||
|     uses: ./.github/workflows/build.yml | ||||
|     with: | ||||
|       ref: ${{ github.ref }} | ||||
|       repo: ${{ github.repository }} | ||||
|       lang: ${{ matrix.lang }} | ||||
|       continue-on-error: true | ||||
|  | ||||
|   buildoffline: | ||||
|     needs: submodule | ||||
|     permissions: | ||||
|       contents: read | ||||
|     uses: ./.github/workflows/build-offline.yml | ||||
|  | ||||
|   cleanup: | ||||
|     if: ${{ always() }} | ||||
|     needs: [build, buildoffline] | ||||
|     uses: privacyguides/.github/.github/workflows/cleanup.yml@main | ||||
							
								
								
									
										81
									
								
								.github/workflows/test-lint.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,81 @@ | ||||
| # 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: 🤖 Linting | ||||
|  | ||||
| permissions: | ||||
|   contents: read | ||||
|  | ||||
| on: | ||||
|   workflow_dispatch: | ||||
|   pull_request: | ||||
|     branches: | ||||
|       - main | ||||
|   push: | ||||
|  | ||||
| concurrency: | ||||
|   group: ${{ github.ref }}-${{ github.workflow }} | ||||
|   cancel-in-progress: true | ||||
|  | ||||
| env: | ||||
|   MAIN_BRANCH: ${{ github.event_name == 'push' }} | ||||
|  | ||||
| jobs: | ||||
|   megalinter: | ||||
|     name: MegaLinter | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|       - if: ${{ env.MAIN_BRANCH }} | ||||
|         uses: actions/checkout@v4 | ||||
|  | ||||
|       - if: ${{ env.MAIN_BRANCH == 0 }} | ||||
|         uses: actions/checkout@v4 | ||||
|         with: | ||||
|           fetch-depth: 0 | ||||
|  | ||||
|       - 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 | ||||
|         env: | ||||
|           # All available variables are described in documentation | ||||
|           # https://megalinter.io/configuration/ | ||||
|           # Validates all source when push on main, else just the git diff with main. | ||||
|           VALIDATE_ALL_CODEBASE: ${{ env.MAIN_BRANCH }} | ||||
|           GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | ||||
|           # 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 | ||||
|           EDITORCONFIG_EDITORCONFIG_CHECKER_ARGUMENTS: -disable-indentation | ||||
|           ENV_DOTENV_LINTER_ARGUMENTS: "--skip QuoteCharacter" | ||||
|           MARKDOWN_MARKDOWN_LINK_CHECK_FILTER_REGEX_INCLUDE: (docs) | ||||
|           MARKDOWN_MARKDOWNLINT_CONFIG_FILE: .markdownlint.yml | ||||
|           MARKDOWN_MARKDOWNLINT_FILTER_REGEX_EXCLUDE: (PULL_REQUEST_TEMPLATE\.md) | ||||
|  | ||||
|       # Upload MegaLinter artifacts | ||||
|       - name: Archive production artifacts | ||||
|         if: success() || failure() | ||||
|         uses: actions/upload-artifact@v4 | ||||
|         with: | ||||
|           name: MegaLinter reports | ||||
|           path: | | ||||
|             megalinter-reports | ||||
|             mega-linter.log | ||||
							
								
								
									
										53
									
								
								.github/workflows/upload-crowdin.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,53 @@ | ||||
| # Copyright (c) 2022-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: 💬 Crowdin Upload | ||||
|  | ||||
| permissions: | ||||
|   contents: read | ||||
|  | ||||
| on: | ||||
|   workflow_dispatch: | ||||
|   push: | ||||
|     branches: [main] | ||||
|  | ||||
| concurrency: | ||||
|   group: ${{ github.workflow }}-${{ github.ref }} | ||||
|   cancel-in-progress: true | ||||
|  | ||||
| jobs: | ||||
|   synchronize-with-crowdin: | ||||
|     runs-on: ubuntu-latest | ||||
|  | ||||
|     steps: | ||||
|       - name: Checkout | ||||
|         uses: actions/checkout@v4 | ||||
|  | ||||
|       - name: crowdin action | ||||
|         uses: crowdin/github-action@v1.20.2 | ||||
|         with: | ||||
|           upload_sources: true | ||||
|           upload_sources_args: "--auto-update --delete-obsolete" | ||||
|           download_translations: false | ||||
|           config: crowdin.yml | ||||
|         env: | ||||
|           GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | ||||
|           CROWDIN_PROJECT_ID: ${{ secrets.CROWDIN_PROJECT_ID }} | ||||
|           CROWDIN_PERSONAL_TOKEN: ${{ secrets.CROWDIN_PERSONAL_TOKEN }} | ||||
							
								
								
									
										25
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						| @@ -1,2 +1,25 @@ | ||||
| site | ||||
| .cache | ||||
| /i18n/ | ||||
| /includes/* | ||||
| !/includes/*.en.* | ||||
| /static/i18n/ | ||||
| /theme/overrides/*.*.* | ||||
|  | ||||
| # commit social card fonts to repo | ||||
| # 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 | ||||
|  | ||||
| # Local Netlify folder | ||||
| .netlify | ||||
| node_modules | ||||
|  | ||||
| # Python | ||||
| .venv | ||||
|   | ||||
							
								
								
									
										6
									
								
								.gitmodules
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,6 @@ | ||||
| [submodule "theme/assets/brand"] | ||||
| 	path = theme/assets/brand | ||||
| 	url = https://github.com/privacyguides/brand.git | ||||
| [submodule "modules/mkdocs-material"] | ||||
| 	path = modules/mkdocs-material | ||||
| 	url = git@github.com:privacyguides/mkdocs-material-insiders.git | ||||
							
								
								
									
										30
									
								
								.markdownlint.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,30 @@ | ||||
| # Copyright (c) 2022 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. | ||||
|  | ||||
| default: true | ||||
| line-length: false | ||||
| ul-indent: | ||||
|   indent: 4 | ||||
| no-inline-html: false | ||||
| code-block-style: false | ||||
| no-hard-tabs: true | ||||
| emphasis-style: | ||||
|   style: "asterisk" | ||||
| no-duplicate-header: false | ||||
							
								
								
									
										1
									
								
								.python-version
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1 @@ | ||||
| 3.12 | ||||
							
								
								
									
										1
									
								
								.vscode/.empty-schema.json
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1 @@ | ||||
| {} | ||||
							
								
								
									
										31
									
								
								.vscode/extensions.json
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,31 @@ | ||||
| // 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. | ||||
|  | ||||
| { | ||||
|   "recommendations": [ | ||||
|     "EditorConfig.EditorConfig", | ||||
|     "DavidAnson.vscode-markdownlint", | ||||
|     "wholroyd.jinja", | ||||
|     "mikestead.dotenv", | ||||
|     "redhat.vscode-yaml", | ||||
|     "ecmel.vscode-html-css", | ||||
|     "yzhang.markdown-all-in-one" | ||||
|   ] | ||||
| } | ||||
							
								
								
									
										48
									
								
								.vscode/settings.json
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,48 @@ | ||||
| // 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. | ||||
|  | ||||
| { | ||||
|     "git.ignoreLimitWarning": true, | ||||
|     "ltex.diagnosticSeverity": "hint", | ||||
|     "editor.unicodeHighlight.ambiguousCharacters": true, | ||||
|     "editor.unicodeHighlight.invisibleCharacters": true, | ||||
|     "editor.defaultFormatter": "DavidAnson.vscode-markdownlint", | ||||
|     "[yaml]": { | ||||
|       "editor.defaultFormatter": "redhat.vscode-yaml", | ||||
|       "editor.quickSuggestions": { | ||||
|         "other": true, | ||||
|         "comments": false, | ||||
|         "strings": true | ||||
|       } | ||||
|     }, | ||||
|     "yaml.schemas": { | ||||
|       "https://raw.githubusercontent.com/DavidAnson/markdownlint/main/schema/markdownlint-config-schema.json": ".markdownlint.yml", | ||||
|       "https://json.schemastore.org/github-issue-config.json": ".github/ISSUE_TEMPLATE/config.yml", | ||||
|       ".vscode/.empty-schema.json": "config/*.yml" | ||||
|     }, | ||||
|     "yaml.customTags": [ | ||||
|       "!ENV sequence", | ||||
|       "!ENV", | ||||
|       "tag:yaml.org,2002:python/name:pymdownx.superfences.fence_code_format", | ||||
|       "tag:yaml.org,2002:python/name:material.extensions.emoji.twemoji", | ||||
|       "tag:yaml.org,2002:python/name:material.extensions.emoji.to_svg" | ||||
|     ], | ||||
|     "editor.formatOnSave": true | ||||
| } | ||||
| @@ -1,5 +0,0 @@ | ||||
| { | ||||
|     "m.homeserver": { | ||||
|         "base_url": "https://dendrite-client.privacyguides.org" | ||||
|     } | ||||
| } | ||||
| @@ -1,3 +0,0 @@ | ||||
| { | ||||
|     "m.server": "dendrite-federation.privacyguides.org:443" | ||||
| } | ||||
| @@ -1,5 +0,0 @@ | ||||
| Contact: jonah@triplebit.net | ||||
| Encryption: https://www.jonaharagon.com/keys/ | ||||
| Preferred-Languages: en | ||||
| Canonical: https://privacyguides.org/.well-known/security.txt | ||||
| Policy: https://github.com/privacyguides/privacyguides.org/security/policy | ||||
							
								
								
									
										98
									
								
								CITATION.cff
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,98 @@ | ||||
| # Copyright (c) 2022-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. | ||||
|  | ||||
| cff-version: 1.2.0 | ||||
| title: Privacy Guides | ||||
| message: "If you reference this website, please cite it in your work." | ||||
| type: software | ||||
| authors: | ||||
|   - family-names: Aragon | ||||
|     given-names: Jonah | ||||
|     website: "https://www.jonaharagon.com" | ||||
|     orcid: "https://orcid.org/0000-0001-6996-4965" | ||||
|   - name: The Privacy Guides Team | ||||
|     website: "https://github.com/orgs/privacyguides/people" | ||||
| repository-code: "https://github.com/privacyguides/privacyguides.org" | ||||
| license: | ||||
|   - MIT | ||||
|   - CC-BY-ND-4.0 | ||||
| references: | ||||
|   - authors: | ||||
|     - family-names: Donath | ||||
|       given-names: Martin | ||||
|     title: "mkdocs-material" | ||||
|     type: software | ||||
|     repository-code: "https://github.com/squidfunk/mkdocs-material" | ||||
|     license: MIT | ||||
| preferred-citation: | ||||
|   type: website | ||||
|   title: Privacy Guides | ||||
|   authors: | ||||
|     - family-names: Aragon | ||||
|       given-names: Jonah | ||||
|       website: "https://www.jonaharagon.com" | ||||
|       orcid: "https://orcid.org/0000-0001-6996-4965" | ||||
|     - family-names: Gray | ||||
|       given-names: Daniel | ||||
|       alias: dngray | ||||
|       website: "https://polarbear.army" | ||||
|     - family-names: Wilde | ||||
|       given-names: Niek | ||||
|       name-particle: de | ||||
|       alias: blacklight447 | ||||
|     - given-names: Freddy | ||||
|       website: "https://freddy.lol" | ||||
|     - alias: mfwmyfacewhen | ||||
|       website: "https://github.com/mfwmyfacewhen" | ||||
|     - given-names: Olivia | ||||
|       alias: hook | ||||
|     - alias: nitrohorse | ||||
|       website: "https://nitrohorse.com" | ||||
|     - family-names: Suomalainen | ||||
|       given-names: Aminda | ||||
|       alias: Mikaela | ||||
|       website: "https://aminda.eu" | ||||
|     - family-names: Potocki | ||||
|       given-names: Dawid | ||||
|       website: "https://dawidpotocki.com" | ||||
|     - alias: matchboxbananasynergy | ||||
|       website: "https://banana.omg.lol" | ||||
|     - family-names: Tran | ||||
|       given-names: Thien | ||||
|       alias: Tommy | ||||
|       website: "https://tommytran.io" | ||||
|     - alias: samsepi0l | ||||
|       website: "https://github.com/d4rklynk" | ||||
|     - name: Privacy Guides Contributors | ||||
|       website: "https://github.com/privacyguides/privacyguides.org/graphs/contributors" | ||||
|   url: "https://www.privacyguides.org" | ||||
|   abstract: >- | ||||
|     Privacy Guides is a socially motivated website that | ||||
|     provides information for protecting your data | ||||
|     security and privacy. We are a non-profit | ||||
|     collective operated entirely by volunteer team | ||||
|     members and contributors. | ||||
|   keywords: | ||||
|     - privacy | ||||
|     - surveillance | ||||
|     - encryption | ||||
|     - website | ||||
|     - markdown | ||||
|   license: CC-BY-ND-4.0 | ||||
							
								
								
									
										71
									
								
								Dockerfile
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,71 @@ | ||||
| FROM python:3.12-alpine as base | ||||
|  | ||||
| LABEL org.opencontainers.image.source="https://github.com/privacyguides/privacyguides.org" | ||||
|  | ||||
| # Setup env | ||||
| ENV LANG C.UTF-8 | ||||
| ENV LC_ALL C.UTF-8 | ||||
| ENV PYTHONDONTWRITEBYTECODE 1 | ||||
| ENV PYTHONFAULTHANDLER 1 | ||||
|  | ||||
| FROM base AS python-deps | ||||
|  | ||||
| # Install pipenv and compilation dependencies | ||||
| RUN pip install pipenv | ||||
| RUN \ | ||||
|   apk upgrade --update-cache -a \ | ||||
| && \ | ||||
|   apk add --no-cache \ | ||||
|     gcc \ | ||||
|     libffi-dev \ | ||||
|     musl-dev | ||||
|  | ||||
| # Install python dependencies in /.venv | ||||
| COPY modules/mkdocs-material ./modules/mkdocs-material | ||||
| COPY Pipfile . | ||||
| COPY Pipfile.lock . | ||||
| RUN PIPENV_VENV_IN_PROJECT=1 pipenv install --deploy | ||||
|  | ||||
| FROM base AS runtime | ||||
|  | ||||
| # Install runtime dependencies | ||||
| RUN \ | ||||
|   apk upgrade --update-cache -a \ | ||||
| && \ | ||||
|   apk add --no-cache \ | ||||
|     cairo \ | ||||
|     freetype-dev \ | ||||
|     git \ | ||||
|     git-fast-import \ | ||||
|     jpeg-dev \ | ||||
|     openssh \ | ||||
|     pngquant \ | ||||
|     tini \ | ||||
|     zlib-dev \ | ||||
|     libffi-dev \ | ||||
|     musl-dev | ||||
|  | ||||
| # Copy virtual env from python-deps stage | ||||
| COPY --from=python-deps /.venv /.venv | ||||
| COPY --from=python-deps /modules/mkdocs-material /modules/mkdocs-material | ||||
| ENV PATH="/.venv/bin:$PATH" | ||||
|  | ||||
| # Create and switch to a new user | ||||
| RUN mkdir /site | ||||
| 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 | ||||
|  | ||||
| EXPOSE 8000 | ||||
|  | ||||
| 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"] | ||||
							
								
								
									
										468
									
								
								LICENSE
									
									
									
									
									
								
							
							
						
						| @@ -1,116 +1,392 @@ | ||||
| CC0 1.0 Universal | ||||
| Attribution-NoDerivatives 4.0 International | ||||
|  | ||||
| Statement of Purpose | ||||
| ======================================================================= | ||||
|  | ||||
| The laws of most jurisdictions throughout the world automatically confer | ||||
| exclusive Copyright and Related Rights (defined below) upon the creator and | ||||
| subsequent owner(s) (each and all, an "owner") of an original work of | ||||
| authorship and/or a database (each, a "Work"). | ||||
| Creative Commons Corporation ("Creative Commons") is not a law firm and | ||||
| does not provide legal services or legal advice. Distribution of | ||||
| Creative Commons public licenses does not create a lawyer-client or | ||||
| other relationship. Creative Commons makes its licenses and related | ||||
| information available on an "as-is" basis. Creative Commons gives no | ||||
| warranties regarding its licenses, any material licensed under their | ||||
| terms and conditions, or any related information. Creative Commons | ||||
| disclaims all liability for damages resulting from their use to the | ||||
| fullest extent possible. | ||||
|  | ||||
| Certain owners wish to permanently relinquish those rights to a Work for the | ||||
| purpose of contributing to a commons of creative, cultural and scientific | ||||
| works ("Commons") that the public can reliably and without fear of later | ||||
| claims of infringement build upon, modify, incorporate in other works, reuse | ||||
| and redistribute as freely as possible in any form whatsoever and for any | ||||
| purposes, including without limitation commercial purposes. These owners may | ||||
| contribute to the Commons to promote the ideal of a free culture and the | ||||
| further production of creative, cultural and scientific works, or to gain | ||||
| reputation or greater distribution for their Work in part through the use and | ||||
| efforts of others. | ||||
| Using Creative Commons Public Licenses | ||||
|  | ||||
| For these and/or other purposes and motivations, and without any expectation | ||||
| of additional consideration or compensation, the person associating CC0 with a | ||||
| Work (the "Affirmer"), to the extent that he or she is an owner of Copyright | ||||
| and Related Rights in the Work, voluntarily elects to apply CC0 to the Work | ||||
| and publicly distribute the Work under its terms, with knowledge of his or her | ||||
| Copyright and Related Rights in the Work and the meaning and intended legal | ||||
| effect of CC0 on those rights. | ||||
| Creative Commons public licenses provide a standard set of terms and | ||||
| conditions that creators and other rights holders may use to share | ||||
| original works of authorship and other material subject to copyright | ||||
| and certain other rights specified in the public license below. The | ||||
| following considerations are for informational purposes only, are not | ||||
| exhaustive, and do not form part of our licenses. | ||||
|  | ||||
| 1. Copyright and Related Rights. A Work made available under CC0 may be | ||||
| protected by copyright and related or neighboring rights ("Copyright and | ||||
| Related Rights"). Copyright and Related Rights include, but are not limited | ||||
| to, the following: | ||||
|      Considerations for licensors: Our public licenses are | ||||
|      intended for use by those authorized to give the public | ||||
|      permission to use material in ways otherwise restricted by | ||||
|      copyright and certain other rights. Our licenses are | ||||
|      irrevocable. Licensors should read and understand the terms | ||||
|      and conditions of the license they choose before applying it. | ||||
|      Licensors should also secure all rights necessary before | ||||
|      applying our licenses so that the public can reuse the | ||||
|      material as expected. Licensors should clearly mark any | ||||
|      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 | ||||
|  | ||||
|   i. the right to reproduce, adapt, distribute, perform, display, communicate, | ||||
|   and translate a Work; | ||||
|      Considerations for the public: By using one of our public | ||||
|      licenses, a licensor grants the public permission to use the | ||||
|      licensed material under specified terms and conditions. If | ||||
|      the licensor's permission is not necessary for any reason--for | ||||
|      example, because of any applicable exception or limitation to | ||||
|      copyright--then that use is not regulated by the license. Our | ||||
|      licenses grant only permissions under copyright and certain | ||||
|      other rights that a licensor has authority to grant. Use of | ||||
|      the licensed material may still be restricted for other | ||||
|      reasons, including because others have copyright or other | ||||
|      rights in the material. A licensor may make special requests, | ||||
|      such as asking that all changes be marked or described. | ||||
|      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 | ||||
|  | ||||
|   ii. moral rights retained by the original author(s) and/or performer(s); | ||||
|  | ||||
|   iii. publicity and privacy rights pertaining to a person's image or likeness | ||||
|   depicted in a Work; | ||||
| ======================================================================= | ||||
|  | ||||
|   iv. rights protecting against unfair competition in regards to a Work, | ||||
|   subject to the limitations in paragraph 4(a), below; | ||||
| Creative Commons Attribution-NoDerivatives 4.0 International Public | ||||
| License | ||||
|  | ||||
|   v. rights protecting the extraction, dissemination, use and reuse of data in | ||||
|   a Work; | ||||
| 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 | ||||
| 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 | ||||
| such rights in consideration of benefits the Licensor receives from | ||||
| making the Licensed Material available under these terms and | ||||
| conditions. | ||||
|  | ||||
|   vi. database rights (such as those arising under Directive 96/9/EC of the | ||||
|   European Parliament and of the Council of 11 March 1996 on the legal | ||||
|   protection of databases, and under any national implementation thereof, | ||||
|   including any amended or successor version of such directive); and | ||||
|  | ||||
|   vii. other similar, equivalent or corresponding rights throughout the world | ||||
|   based on applicable law or treaty, and any national implementations thereof. | ||||
| Section 1 -- Definitions. | ||||
|  | ||||
| 2. Waiver. To the greatest extent permitted by, but not in contravention of, | ||||
| applicable law, Affirmer hereby overtly, fully, permanently, irrevocably and | ||||
| unconditionally waives, abandons, and surrenders all of Affirmer's Copyright | ||||
| and Related Rights and associated claims and causes of action, whether now | ||||
| known or unknown (including existing as well as future claims and causes of | ||||
| action), in the Work (i) in all territories worldwide, (ii) for the maximum | ||||
| duration provided by applicable law or treaty (including future time | ||||
| extensions), (iii) in any current or future medium and for any number of | ||||
| copies, and (iv) for any purpose whatsoever, including without limitation | ||||
| commercial, advertising or promotional purposes (the "Waiver"). Affirmer makes | ||||
| the Waiver for the benefit of each member of the public at large and to the | ||||
| detriment of Affirmer's heirs and successors, fully intending that such Waiver | ||||
| shall not be subject to revocation, rescission, cancellation, termination, or | ||||
| any other legal or equitable action to disrupt the quiet enjoyment of the Work | ||||
| by the public as contemplated by Affirmer's express Statement of Purpose. | ||||
|   a. Adapted Material means material subject to Copyright and Similar | ||||
|      Rights that is derived from or based upon the Licensed Material | ||||
|      and in which the Licensed Material is translated, altered, | ||||
|      arranged, transformed, or otherwise modified in a manner requiring | ||||
|      permission under the Copyright and Similar Rights held by the | ||||
|      Licensor. For purposes of this Public License, where the Licensed | ||||
|      Material is a musical work, performance, or sound recording, | ||||
|      Adapted Material is always produced where the Licensed Material is | ||||
|      synched in timed relation with a moving image. | ||||
|  | ||||
| 3. Public License Fallback. Should any part of the Waiver for any reason be | ||||
| judged legally invalid or ineffective under applicable law, then the Waiver | ||||
| shall be preserved to the maximum extent permitted taking into account | ||||
| Affirmer's express Statement of Purpose. In addition, to the extent the Waiver | ||||
| is so judged Affirmer hereby grants to each affected person a royalty-free, | ||||
| non transferable, non sublicensable, non exclusive, irrevocable and | ||||
| unconditional license to exercise Affirmer's Copyright and Related Rights in | ||||
| the Work (i) in all territories worldwide, (ii) for the maximum duration | ||||
| provided by applicable law or treaty (including future time extensions), (iii) | ||||
| in any current or future medium and for any number of copies, and (iv) for any | ||||
| purpose whatsoever, including without limitation commercial, advertising or | ||||
| promotional purposes (the "License"). The License shall be deemed effective as | ||||
| of the date CC0 was applied by Affirmer to the Work. Should any part of the | ||||
| License for any reason be judged legally invalid or ineffective under | ||||
| applicable law, such partial invalidity or ineffectiveness shall not | ||||
| invalidate the remainder of the License, and in such case Affirmer hereby | ||||
| affirms that he or she will not (i) exercise any of his or her remaining | ||||
| Copyright and Related Rights in the Work or (ii) assert any associated claims | ||||
| and causes of action with respect to the Work, in either case contrary to | ||||
| Affirmer's express Statement of Purpose. | ||||
|   b. 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 | ||||
|      categorized. For purposes of this Public License, the rights | ||||
|      specified in Section 2(b)(1)-(2) are not Copyright and Similar | ||||
|      Rights. | ||||
|  | ||||
| 4. Limitations and Disclaimers. | ||||
|   c. 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. | ||||
|  | ||||
|   a. No trademark or patent rights held by Affirmer are waived, abandoned, | ||||
|   surrendered, licensed or otherwise affected by this document. | ||||
|   d. 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. | ||||
|  | ||||
|   b. Affirmer offers the Work as-is and makes no representations or warranties | ||||
|   of any kind concerning the Work, express, implied, statutory or otherwise, | ||||
|   including without limitation warranties of title, merchantability, fitness | ||||
|   for a particular purpose, non infringement, or the absence of latent or | ||||
|   other defects, accuracy, or the present or absence of errors, whether or not | ||||
|   discoverable, all to the greatest extent permissible under applicable law. | ||||
|   e. Licensed Material means the artistic or literary work, database, | ||||
|      or other material to which the Licensor applied this Public | ||||
|      License. | ||||
|  | ||||
|   c. Affirmer disclaims responsibility for clearing rights of other persons | ||||
|   that may apply to the Work or any use thereof, including without limitation | ||||
|   any person's Copyright and Related Rights in the Work. Further, Affirmer | ||||
|   disclaims responsibility for obtaining any necessary consents, permissions | ||||
|   or other rights required for any use of the Work. | ||||
|   f. 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. | ||||
|  | ||||
|   d. Affirmer understands and acknowledges that Creative Commons is not a | ||||
|   party to this document and has no duty or obligation with respect to this | ||||
|   CC0 or use of the Work. | ||||
|   g. Licensor means the individual(s) or entity(ies) granting rights | ||||
|      under this Public License. | ||||
|  | ||||
| For more information, please see | ||||
| <http://creativecommons.org/publicdomain/zero/1.0/> | ||||
|   h. 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 | ||||
|      available to the public including in ways that members of the | ||||
|      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 | ||||
|      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 | ||||
|      under this Public License. Your has a corresponding meaning. | ||||
|  | ||||
|  | ||||
| Section 2 -- Scope. | ||||
|  | ||||
|   a. License grant. | ||||
|  | ||||
|        1. Subject to the terms and conditions of this Public License, | ||||
|           the Licensor hereby grants You a worldwide, royalty-free, | ||||
|           non-sublicensable, non-exclusive, irrevocable license to | ||||
|           exercise the Licensed Rights in the Licensed Material to: | ||||
|  | ||||
|             a. reproduce and Share the Licensed Material, in whole or | ||||
|                in part; and | ||||
|  | ||||
|             b. produce and reproduce, but not Share, Adapted Material. | ||||
|  | ||||
|        2. Exceptions and Limitations. For the avoidance of doubt, where | ||||
|           Exceptions and Limitations apply to Your use, this Public | ||||
|           License does not apply, and You do not need to comply with | ||||
|           its terms and conditions. | ||||
|  | ||||
|        3. Term. The term of this Public License is specified in Section | ||||
|           6(a). | ||||
|  | ||||
|        4. Media and formats; technical modifications allowed. The | ||||
|           Licensor authorizes You to exercise the Licensed Rights in | ||||
|           all media and formats whether now known or hereafter created, | ||||
|           and to make technical modifications necessary to do so. The | ||||
|           Licensor waives and/or agrees not to assert any right or | ||||
|           authority to forbid You from making technical modifications | ||||
|           necessary to exercise the Licensed Rights, including | ||||
|           technical modifications necessary to circumvent Effective | ||||
|           Technological Measures. For purposes of this Public License, | ||||
|           simply making modifications authorized by this Section 2(a) | ||||
|           (4) never produces Adapted Material. | ||||
|  | ||||
|        5. Downstream recipients. | ||||
|  | ||||
|             a. Offer from the Licensor -- Licensed Material. Every | ||||
|                recipient of the Licensed Material automatically | ||||
|                receives an offer from the Licensor to exercise the | ||||
|                Licensed Rights under the terms and conditions of this | ||||
|                Public License. | ||||
|  | ||||
|             b. 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 | ||||
|                Licensed Rights by any recipient of the Licensed | ||||
|                Material. | ||||
|  | ||||
|        6. No endorsement. Nothing in this Public License constitutes or | ||||
|           may be construed as permission to assert or imply that You | ||||
|           are, or that Your use of the Licensed Material is, connected | ||||
|           with, or sponsored, endorsed, or granted official status by, | ||||
|           the Licensor or others designated to receive attribution as | ||||
|           provided in Section 3(a)(1)(A)(i). | ||||
|  | ||||
|   b. Other rights. | ||||
|  | ||||
|        1. Moral rights, such as the right of integrity, are not | ||||
|           licensed under this Public License, nor are publicity, | ||||
|           privacy, and/or other similar personality rights; however, to | ||||
|           the extent possible, the Licensor waives and/or agrees not to | ||||
|           assert any such rights held by the Licensor to the limited | ||||
|           extent necessary to allow You to exercise the Licensed | ||||
|           Rights, but not otherwise. | ||||
|  | ||||
|        2. Patent and trademark rights are not licensed under this | ||||
|           Public License. | ||||
|  | ||||
|        3. To the extent possible, the Licensor waives any right to | ||||
|           collect royalties from You for the exercise of the Licensed | ||||
|           Rights, whether directly or through a collecting society | ||||
|           under any voluntary or waivable statutory or compulsory | ||||
|           licensing scheme. In all other cases the Licensor expressly | ||||
|           reserves any right to collect such royalties. | ||||
|  | ||||
|  | ||||
| Section 3 -- License Conditions. | ||||
|  | ||||
| Your exercise of the Licensed Rights is expressly made subject to the | ||||
| following conditions. | ||||
|  | ||||
|   a. Attribution. | ||||
|  | ||||
|        1. If You Share the Licensed Material, You must: | ||||
|  | ||||
|             a. retain the following if it is supplied by the Licensor | ||||
|                with the Licensed Material: | ||||
|  | ||||
|                  i. identification of the creator(s) of the Licensed | ||||
|                     Material and any others designated to receive | ||||
|                     attribution, in any reasonable manner requested by | ||||
|                     the Licensor (including by pseudonym if | ||||
|                     designated); | ||||
|  | ||||
|                 ii. a copyright notice; | ||||
|  | ||||
|                iii. a notice that refers to this Public License; | ||||
|  | ||||
|                 iv. a notice that refers to the disclaimer of | ||||
|                     warranties; | ||||
|  | ||||
|                  v. a URI or hyperlink to the Licensed Material to the | ||||
|                     extent reasonably practicable; | ||||
|  | ||||
|             b. indicate if You modified the Licensed Material and | ||||
|                retain an indication of any previous modifications; and | ||||
|  | ||||
|             c. indicate the Licensed Material is licensed under this | ||||
|                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 | ||||
|           reasonable to satisfy the conditions by providing a URI or | ||||
|           hyperlink to a resource that includes the required | ||||
|           information. | ||||
|  | ||||
|        3. If requested by the Licensor, You must remove any of the | ||||
|           information required by Section 3(a)(1)(A) to the extent | ||||
|           reasonably practicable. | ||||
|  | ||||
|  | ||||
| Section 4 -- Sui Generis Database Rights. | ||||
|  | ||||
| Where the Licensed Rights include Sui Generis Database Rights that | ||||
| 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; | ||||
|  | ||||
|   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 | ||||
|  | ||||
|   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. | ||||
|  | ||||
| For the avoidance of doubt, this Section 4 supplements and does not | ||||
| replace Your obligations under this Public License where the Licensed | ||||
| Rights include other Copyright and Similar Rights. | ||||
|  | ||||
|  | ||||
| Section 5 -- Disclaimer of Warranties and Limitation of Liability. | ||||
|  | ||||
|   a. UNLESS OTHERWISE SEPARATELY UNDERTAKEN BY THE LICENSOR, TO THE | ||||
|      EXTENT POSSIBLE, THE LICENSOR OFFERS THE LICENSED MATERIAL AS-IS | ||||
|      AND AS-AVAILABLE, AND MAKES NO REPRESENTATIONS OR WARRANTIES OF | ||||
|      ANY KIND CONCERNING THE LICENSED MATERIAL, WHETHER EXPRESS, | ||||
|      IMPLIED, STATUTORY, OR OTHER. THIS INCLUDES, WITHOUT LIMITATION, | ||||
|      WARRANTIES OF TITLE, MERCHANTABILITY, FITNESS FOR A PARTICULAR | ||||
|      PURPOSE, NON-INFRINGEMENT, ABSENCE OF LATENT OR OTHER DEFECTS, | ||||
|      ACCURACY, OR THE PRESENCE OR ABSENCE OF ERRORS, WHETHER OR NOT | ||||
|      KNOWN OR DISCOVERABLE. WHERE DISCLAIMERS OF WARRANTIES ARE NOT | ||||
|      ALLOWED IN FULL OR IN PART, THIS DISCLAIMER MAY NOT APPLY TO YOU. | ||||
|  | ||||
|   b. TO THE EXTENT POSSIBLE, IN NO EVENT WILL THE LICENSOR BE LIABLE | ||||
|      TO YOU ON ANY LEGAL THEORY (INCLUDING, WITHOUT LIMITATION, | ||||
|      NEGLIGENCE) OR OTHERWISE FOR ANY DIRECT, SPECIAL, INDIRECT, | ||||
|      INCIDENTAL, CONSEQUENTIAL, PUNITIVE, EXEMPLARY, OR OTHER LOSSES, | ||||
|      COSTS, EXPENSES, OR DAMAGES ARISING OUT OF THIS PUBLIC LICENSE OR | ||||
|      USE OF THE LICENSED MATERIAL, EVEN IF THE LICENSOR HAS BEEN | ||||
|      ADVISED OF THE POSSIBILITY OF SUCH LOSSES, COSTS, EXPENSES, OR | ||||
|      DAMAGES. WHERE A LIMITATION OF LIABILITY IS NOT ALLOWED IN FULL OR | ||||
|      IN PART, THIS LIMITATION MAY NOT APPLY TO YOU. | ||||
|  | ||||
|   c. The disclaimer of warranties and limitation of liability provided | ||||
|      above shall be interpreted in a manner that, to the extent | ||||
|      possible, most closely approximates an absolute disclaimer and | ||||
|      waiver of all liability. | ||||
|  | ||||
|  | ||||
| Section 6 -- Term and Termination. | ||||
|  | ||||
|   a. This Public License applies for the term of the Copyright and | ||||
|      Similar Rights licensed here. However, if You fail to comply with | ||||
|      this Public License, then Your rights under this Public License | ||||
|      terminate automatically. | ||||
|  | ||||
|   b. Where Your right to use the Licensed Material has terminated under | ||||
|      Section 6(a), it reinstates: | ||||
|  | ||||
|        1. automatically as of the date the violation is cured, provided | ||||
|           it is cured within 30 days of Your discovery of the | ||||
|           violation; or | ||||
|  | ||||
|        2. upon express reinstatement by the Licensor. | ||||
|  | ||||
|      For the avoidance of doubt, this Section 6(b) does not affect any | ||||
|      right the Licensor may have to seek remedies for Your violations | ||||
|      of this Public License. | ||||
|  | ||||
|   c. For the avoidance of doubt, the Licensor may also offer the | ||||
|      Licensed Material under separate terms or conditions or stop | ||||
|      distributing the Licensed Material at any time; however, doing so | ||||
|      will not terminate this Public License. | ||||
|  | ||||
|   d. Sections 1, 5, 6, 7, and 8 survive termination of this Public | ||||
|      License. | ||||
|  | ||||
|  | ||||
| Section 7 -- Other Terms and Conditions. | ||||
|  | ||||
|   a. The Licensor shall not be bound by any additional or different | ||||
|      terms or conditions communicated by You unless expressly agreed. | ||||
|  | ||||
|   b. Any arrangements, understandings, or agreements regarding the | ||||
|      Licensed Material not stated herein are separate from and | ||||
|      independent of the terms and conditions of this Public License. | ||||
|  | ||||
|  | ||||
| Section 8 -- Interpretation. | ||||
|  | ||||
|   a. For the avoidance of doubt, this Public License does not, and | ||||
|      shall not be interpreted to, reduce, limit, restrict, or impose | ||||
|      conditions on any use of the Licensed Material that could lawfully | ||||
|      be made without permission under this Public License. | ||||
|  | ||||
|   b. To the extent possible, if any provision of this Public License is | ||||
|      deemed unenforceable, it shall be automatically reformed to the | ||||
|      minimum extent necessary to make it enforceable. If the provision | ||||
|      cannot be reformed, it shall be severed from this Public License | ||||
|      without affecting the enforceability of the remaining terms and | ||||
|      conditions. | ||||
|  | ||||
|   c. No term or condition of this Public License will be waived and no | ||||
|      failure to comply consented to unless expressly agreed to by the | ||||
|      Licensor. | ||||
|  | ||||
|   d. Nothing in this Public License constitutes or may be interpreted | ||||
|      as a limitation upon, or waiver of, any privileges and immunities | ||||
|      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 | ||||
| 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. | ||||
|  | ||||
| Creative Commons may be contacted at creativecommons.org. | ||||
|   | ||||
							
								
								
									
										22
									
								
								LICENSE-CODE
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,22 @@ | ||||
| MIT License | ||||
|  | ||||
| Copyright (c) 2019 - 2024 Jonah Aragon <jonah@triplebit.net> | ||||
| Copyright (c) 2020 - 2024 Privacy Guides contributors | ||||
|  | ||||
| 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 NONINFRINGEMENT. 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. | ||||
							
								
								
									
										37
									
								
								Pipfile
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,37 @@ | ||||
| # Copyright (c) 2022-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. | ||||
|  | ||||
| [[source]] | ||||
| url = "https://pypi.org/simple" | ||||
| verify_ssl = true | ||||
| 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-macros-plugin = "~=1.0" | ||||
| jieba = "~=0.42" | ||||
|  | ||||
| [dev-packages] | ||||
| scour = "~=0.38" | ||||
|  | ||||
| [requires] | ||||
| python_version = "3.12" | ||||
							
								
								
									
										1007
									
								
								Pipfile.lock
									
									
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						
							
								
								
									
										134
									
								
								README.md
									
									
									
									
									
								
							
							
						
						| @@ -1,41 +1,131 @@ | ||||
| <!-- markdownlint-disable MD041 MD045 --> | ||||
| <div align="center"> | ||||
|   <a href="https://privacyguides.org"> | ||||
|     <img src="/docs/assets/img/layout/privacy-guides-logo.svg" width="500px" alt="Privacy Guides" /> | ||||
|   <a href="https://www.privacyguides.org"> | ||||
|     <picture> | ||||
|       <source media="(prefers-color-scheme: dark)" srcset="https://raw.githubusercontent.com/privacyguides/brand/67166ed8b641d8ac1837d0b75329e02ed4056704/logos/svg/logo/privacy-guides-logo-dark.svg"> | ||||
|       <img alt="Privacy Guides" width="500px" src="https://raw.githubusercontent.com/privacyguides/brand/67166ed8b641d8ac1837d0b75329e02ed4056704/logos/svg/logo/privacy-guides-logo.svg"> | ||||
|     </picture> | ||||
|   </a> | ||||
|  | ||||
|   <p><em>Your central privacy and security resource to protect yourself online.</em></p> | ||||
|  | ||||
|   <a href="https://opencollective.com/privacyguides"> | ||||
|     <img src="https://img.shields.io/opencollective/all/privacyguides"> | ||||
|   </a></p> | ||||
|  | ||||
|   <p><a href="https://www.reddit.com/r/PrivacyGuides/"> | ||||
|     <img src="https://img.shields.io/reddit/subreddit-subscribers/PrivacyGuides?label=Subscribe%20to%20r%2FPrivacyGuides&style=social"> | ||||
|   </a> | ||||
|   <a href="https://twitter.com/privacy_guides"> | ||||
|     <img src="https://img.shields.io/twitter/follow/privacy_guides?style=social"> | ||||
|   <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> | ||||
|   <a href="https://github.com/privacyguides/privacyguides.org/stargazers"> | ||||
|     <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> | ||||
|  | ||||
|   <a href="https://github.com/privacyguides/privacyguides.org/issues"> | ||||
|     <img src="https://img.shields.io/github/issues-raw/privacyguides/privacyguides.org"> | ||||
|   </a> | ||||
|   <a href="https://github.com/privacyguides/privacyguides.org/issues?q=is%3Aissue+is%3Aclosed"> | ||||
|     <img src="https://img.shields.io/github/issues-closed-raw/privacyguides/privacyguides.org"> | ||||
|   </a> | ||||
|   <a href="https://github.com/privacyguides/privacyguides.org/pulls"> | ||||
|   <p><a href="https://github.com/privacyguides/privacyguides.org/pulls"> | ||||
|     <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> | ||||
|   <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> | ||||
| </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! | ||||
|  | ||||
| *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)* | ||||
|  | ||||
| ## Contributing | ||||
|  | ||||
| - 💬 [Start a discussion or suggest an idea](https://discuss.privacyguides.net) | ||||
| - 💖 [Sponsor the project](https://github.com/sponsors/privacyguides) | ||||
| - 🈴 [Help translate the site](https://crowdin.com/project/privacyguides) [[Matrix chat](https://matrix.to/#/#pg-i18n:aragon.sh)] | ||||
| - 📝 Edit the site, everything's accessible in this repo | ||||
|     - Browse our [open issues](https://github.com/privacyguides/privacyguides.org/issues) to see what needs to be updated | ||||
|     - 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. | ||||
|  | ||||
| ## Mirrors | ||||
|  | ||||
| [](https://github.com/privacyguides/privacyguides.org) | ||||
| [](https://gitlab.com/privacyguides/privacyguides.org) | ||||
| [](https://codeberg.org/privacyguides/privacyguides.org) | ||||
| [](https://code.privacyguides.dev/privacyguides/privacyguides.org) | ||||
| [](https://git.jonaharagon.net/privacyguides/privacyguides.org) | ||||
|  | ||||
| **Hidden service (Tor/onion):** [xoe4vn5uwdztif6goazfbmogh6wh5jc4up35bqdflu6bkdc5cas5vjqd.onion](http://www.xoe4vn5uwdztif6goazfbmogh6wh5jc4up35bqdflu6bkdc5cas5vjqd.onion) | ||||
|  | ||||
| ## License | ||||
|  | ||||
| Copyright © 2019 - 2024 [Privacy Guides contributors](https://github.com/privacyguides/privacyguides.org/graphs/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). | ||||
|  | ||||
| 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. | ||||
|  | ||||
| These licenses do not apply to any work where another license is otherwise noted. | ||||
|  | ||||
| **Logos** in the [`/theme/assets/img`](/theme/assets/img) folder may not be original works of Privacy Guides and therefore cannot be (re)licensed by us. We believe that these logos obtained from third-party providers are either in the public domain or **fair use**. In a nutshell, legal [fair use doctrine](https://copyright.gov/fair-use/more-info.html) allows the use of copyrighted images in order to identify the subject for purposes of public comment. However, these logos and other images may still be subject to trademark laws in one or more jurisdictions. Before using this content, please ensure that it is used to identify the entity or organization that owns the trademark and that you have the right to use it under the laws which apply in the circumstances of your intended use. *When copying content from this website, you are solely responsible for ensuring that you do not infringe someone else's trademark or copyright.* | ||||
|  | ||||
| You may comply with our license terms in any reasonable manner, but not in any way that suggests Privacy Guides endorses you or your use. You **may not** use the Privacy Guides branding in your own project without express approval from this project. Privacy Guides's brand trademarks include the "Privacy Guides" wordmark and shield logo. | ||||
|  | ||||
| When you contribute to this repository you are doing so under the above licenses, and you are granting 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 and distribute your contribution as part of our project. | ||||
|  | ||||
| ## Developing | ||||
|  | ||||
| 1. [Install mkdocs](https://www.mkdocs.org/user-guide/installation/): `pip install mkdocs` | ||||
| 2. [Install mkdocs-material](https://squidfunk.github.io/mkdocs-material/getting-started/): `pip install mkdocs-material` | ||||
| 3. Serve the site locally: `mkdocs serve` | ||||
|     - The site will be available at `http://localhost:8000/`. | ||||
| 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` | ||||
|  | ||||
| ### 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. | ||||
|  | ||||
| **Team members** should clone the repository with `mkdocs-material-insiders` directly. This method is identical to production: | ||||
|  | ||||
| 1. Clone this repository and submodules: `git clone --recurse-submodules https://github.com/privacyguides/privacyguides.org.git` | ||||
| 2. Enable SSH commit verification with our local [`.allowed_signers`](/.allowed_signers) file: `git config gpg.ssh.allowedSignersFile .allowed_signers` | ||||
| 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) | ||||
|     - 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` | ||||
|     - 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. | ||||
|  | ||||
| ### Local Translated Site Builds | ||||
|  | ||||
| 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)) | ||||
|  | ||||
| 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. | ||||
|  | ||||
| ## Releasing | ||||
|  | ||||
| It is required to create a GitHub release to publish the current site to privacyguides.org. The current `main` branch can be previewed at [https://main.staging.privacyguides.dev](https://main.staging.privacyguides.dev) prior to release. | ||||
|  | ||||
| 1. Create a new tag: `git tag -s YYYY.MM.DD -m 'Some message'` | ||||
|     - Tag numbering: `YYYY.MM.DD` - if two+ releases are published on the same day, append short commit sha to next release, e.g. `YYYY.MM.DD-6aa14e8` | ||||
|     - Enable GPG tag signing by default (`git config tag.gpgSign true`) to avoid missing signatures | ||||
| 2. Push the tag to GitHub: `git push --tags` | ||||
| 3. A GitHub Release will be automatically created and deployed to the live site. | ||||
|     - You may wish to manually check or edit the release changelog/title after it is published for accuracy. | ||||
|   | ||||
							
								
								
									
										1
									
								
								config/.cache/plugin/social/fonts
									
									
									
									
									
										Symbolic link
									
								
							
							
						
						| @@ -0,0 +1 @@ | ||||
| ../../../../theme/assets/brand/fonts | ||||
							
								
								
									
										97
									
								
								config/layouts/home.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,97 @@ | ||||
| definitions: | ||||
|   - &background_color >- | ||||
|     #FFD06F | ||||
|  | ||||
|   - &color >- | ||||
|     #2d2d2d | ||||
|  | ||||
|   - &title_font_family >- | ||||
|     Bagnard | ||||
|  | ||||
|   - &font_family >- | ||||
|     {%- if config.theme.language == "he" -%} | ||||
|       Suez One | ||||
|     {%- elif config.theme.language == ("zh-Hant" or "ru") -%} | ||||
|       Noto Sans TC | ||||
|     {%- else -%} | ||||
|       Public Sans | ||||
|     {%- endif -%} | ||||
|  | ||||
|   - &page_title >- | ||||
|     {{ config.site_name }} | ||||
|  | ||||
|   - &page_title_with_site_name >- | ||||
|     {{ page.meta.get("title", page.title) }} | ||||
|  | ||||
|   - &page_description >- | ||||
|     {{ config.extra.privacy_guides.homepage.description }} | ||||
|  | ||||
|   - &og_description >- | ||||
|     {{ page.meta.get("description", config.site_description) or "" }} | ||||
|  | ||||
|   - &logo >- | ||||
|     {{ config.docs_dir }}/{{ config.theme.logo }} | ||||
|  | ||||
| # Meta tags | ||||
| tags: | ||||
|   # Open Graph | ||||
|   og:type: website | ||||
|   og:title: *page_title_with_site_name | ||||
|   og:description: *og_description | ||||
|   og:image: "{{ image.url }}" | ||||
|   og:image:type: "{{ image.type }}" | ||||
|   og:image:width: "{{ image.width }}" | ||||
|   og:image:height: "{{ image.height }}" | ||||
|   og:url: "{{ page.canonical_url }}" | ||||
|  | ||||
|   # Twitter | ||||
|   twitter:card: summary_large_image | ||||
|   twitter.title: *page_title_with_site_name | ||||
|   twitter:description: *page_description | ||||
|   twitter:image: "{{ image.url }}" | ||||
|  | ||||
| # ----------------------------------------------------------------------------- | ||||
| # Specification | ||||
| # ----------------------------------------------------------------------------- | ||||
|  | ||||
| # Card size and layers | ||||
| size: { width: 1200, height: 630 } | ||||
| layers: | ||||
|   # Background | ||||
|   - background: | ||||
|       color: *background_color | ||||
|  | ||||
|   # Logo | ||||
|   - size: { width: 64, height: 64 } | ||||
|     offset: { x: 64, y: 64 } | ||||
|     background: | ||||
|       image: *logo | ||||
|  | ||||
|   # Page title | ||||
|   - size: { width: 864, height: 256 } | ||||
|     offset: { x: 62, y: 192 } | ||||
|     typography: | ||||
|       content: *page_title | ||||
|       align: start | ||||
|       color: *color | ||||
|       line: | ||||
|         amount: 3 | ||||
|         height: 1.5 | ||||
|       font: | ||||
|         family: *title_font_family | ||||
|         style: Bold | ||||
|  | ||||
|   # Page description | ||||
|   - size: { width: 864, height: 192 } | ||||
|     offset: { x: 64, y: 320 } | ||||
|     typography: | ||||
|       content: *page_description | ||||
|       overflow: shrink | ||||
|       align: start | ||||
|       color: *color | ||||
|       line: | ||||
|         amount: 3 | ||||
|         height: 1.5 | ||||
|       font: | ||||
|         family: *font_family | ||||
|         style: Regular | ||||
							
								
								
									
										149
									
								
								config/layouts/page.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,149 @@ | ||||
| definitions: | ||||
|   - &background_image >- | ||||
|     {%- if page.meta.cover -%} | ||||
|       theme/assets/img/cover/{{ page.meta.cover }} | ||||
|     {%- else -%} | ||||
|       {{ layout.background_image or "" }} | ||||
|     {%- endif -%} | ||||
|  | ||||
|   - &background_color >- | ||||
|     {%- if page.meta.cover -%} | ||||
|       #f7f7fcaa | ||||
|     {%- else -%} | ||||
|       #FFD06F | ||||
|     {%- endif -%} | ||||
|  | ||||
|   - &color >- | ||||
|     {{ layout.color or "#2d2d2d" }} | ||||
|  | ||||
|   - &title_font_family >- | ||||
|     {%- if config.theme.language == "he" -%} | ||||
|       Suez One | ||||
|     {%- elif config.theme.language == ("zh-Hant" or "ru") -%} | ||||
|       Noto Serif TC | ||||
|     {%- else -%} | ||||
|       Bagnard | ||||
|     {%- endif -%} | ||||
|  | ||||
|   - &title_font_style >- | ||||
|     {%- if config.theme.language == "he" -%} | ||||
|       Regular | ||||
|     {%- else -%} | ||||
|       Bold | ||||
|     {%- endif -%} | ||||
|  | ||||
|   - &font_family >- | ||||
|     {%- if config.theme.language == "he" -%} | ||||
|       Suez One | ||||
|     {%- elif config.theme.language == ("zh-Hant" or "ru") -%} | ||||
|       Noto Sans TC | ||||
|     {%- else -%} | ||||
|       Public Sans | ||||
|     {%- endif -%} | ||||
|  | ||||
|   - &site_name >- | ||||
|     {{ config.site_name }} | ||||
|  | ||||
|   - &page_title >- | ||||
|     {{ page.meta.get("title", page.title) }} | ||||
|  | ||||
|   - &page_title_with_site_name >- | ||||
|     {%- if page.meta.meta_title -%} | ||||
|       {{ page.meta.meta_title }} | ||||
|     {%- else -%} | ||||
|       {{ page.meta.get("title", page.title) }} - {{ config.site_name }} | ||||
|     {%- endif -%} | ||||
|  | ||||
|   - &page_description >- | ||||
|     {{ page.meta.get("description", config.site_description) or "" }} | ||||
|  | ||||
|   - &page_icon >- | ||||
|     {{ page.meta.icon or "" }} | ||||
|  | ||||
|   - &logo >- | ||||
|     {%- if page.meta.cover -%} | ||||
|       theme/assets/brand/logos/svg/logo/privacy-guides-logo-notext.svg | ||||
|     {%- elif config.theme.logo -%} | ||||
|       {{ config.docs_dir }}/{{ config.theme.logo }} | ||||
|     {%- endif -%} | ||||
|  | ||||
| # Meta tags | ||||
| tags: | ||||
|   # Open Graph | ||||
|   og:type: website | ||||
|   og:title: *page_title_with_site_name | ||||
|   og:description: *page_description | ||||
|   og:image: "{{ image.url }}" | ||||
|   og:image:type: "{{ image.type }}" | ||||
|   og:image:width: "{{ image.width }}" | ||||
|   og:image:height: "{{ image.height }}" | ||||
|   og:url: "{{ page.canonical_url }}" | ||||
|  | ||||
|   # Twitter | ||||
|   twitter:card: summary_large_image | ||||
|   twitter.title: *page_title_with_site_name | ||||
|   twitter:description: *page_description | ||||
|   twitter:image: "{{ image.url }}" | ||||
|  | ||||
| # ----------------------------------------------------------------------------- | ||||
| # Specification | ||||
| # ----------------------------------------------------------------------------- | ||||
|  | ||||
| # Card size and layers | ||||
| size: { width: 1200, height: 630 } | ||||
| layers: | ||||
|   # Background | ||||
|   - background: | ||||
|       image: *background_image | ||||
|       color: *background_color | ||||
|  | ||||
|   # Page icon | ||||
|   - size: { width: 630, height: 630 } | ||||
|     offset: { x: 570, y: 0 } | ||||
|     icon: | ||||
|       value: *page_icon | ||||
|       color: "#00000033" | ||||
|  | ||||
|   # Logo | ||||
|   - size: { width: 64, height: 64 } | ||||
|     offset: { x: 64, y: 64 } | ||||
|     background: | ||||
|       image: *logo | ||||
|  | ||||
|   # Site name | ||||
|   - size: { width: 768, height: 42 } | ||||
|     offset: { x: 160, y: 78 } | ||||
|     typography: | ||||
|       content: *site_name | ||||
|       color: *color | ||||
|       font: | ||||
|         family: Bagnard | ||||
|         style: Bold | ||||
|  | ||||
|   # Page title | ||||
|   - size: { width: 864, height: 256 } | ||||
|     offset: { x: 62, y: 192 } | ||||
|     typography: | ||||
|       content: *page_title | ||||
|       align: start | ||||
|       color: *color | ||||
|       line: | ||||
|         amount: 3 | ||||
|         height: 1.5 | ||||
|       font: | ||||
|         family: *title_font_family | ||||
|         style: *title_font_style | ||||
|  | ||||
|   # Page description | ||||
|   - size: { width: 864, height: 96 } | ||||
|     offset: { x: 64, y: 480 } | ||||
|     typography: | ||||
|       content: *page_description | ||||
|       align: start | ||||
|       color: *color | ||||
|       line: | ||||
|         amount: 3 | ||||
|         height: 1.5 | ||||
|       font: | ||||
|         family: *font_family | ||||
|         style: Regular | ||||
							
								
								
									
										134
									
								
								config/layouts/pride.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,134 @@ | ||||
| definitions: | ||||
|   - &background_image >- | ||||
|     {%- if page.meta.cover -%} | ||||
|       theme/assets/img/cover/{{ page.meta.cover }} | ||||
|     {%- else -%} | ||||
|       {{ layout.background_image or "theme/assets/brand/images/png/cover-progress-notext-blur.png" }} | ||||
|     {%- endif -%} | ||||
|  | ||||
|   - &background_color >- | ||||
|     #f7f7fcaa | ||||
|  | ||||
|   - &color >- | ||||
|     {{ layout.color or "#2d2d2d" }} | ||||
|  | ||||
|   - &title_font_family >- | ||||
|     {%- if config.theme.language == "he" -%} | ||||
|       Suez One | ||||
|     {%- elif config.theme.language == ("zh-Hant" or "ru") -%} | ||||
|       Noto Serif TC | ||||
|     {%- else -%} | ||||
|       Bagnard | ||||
|     {%- endif -%} | ||||
|  | ||||
|   - &font_family >- | ||||
|     {%- if config.theme.language == "he" -%} | ||||
|       Suez One | ||||
|     {%- elif config.theme.language == ("zh-Hant" or "ru") -%} | ||||
|       Noto Sans TC | ||||
|     {%- else -%} | ||||
|       Public Sans | ||||
|     {%- endif -%} | ||||
|  | ||||
|   - &site_name >- | ||||
|     {{ config.site_name }} | ||||
|  | ||||
|   - &page_title >- | ||||
|     {{ page.meta.get("title", page.title) }} | ||||
|  | ||||
|   - &page_title_with_site_name >- | ||||
|     {%- if page.meta.meta_title -%} | ||||
|       {{ page.meta.meta_title }} | ||||
|     {%- else -%} | ||||
|       {{ page.meta.get("title", page.title) }} | ||||
|     {%- endif -%} | ||||
|  | ||||
|   - &page_description >- | ||||
|     {{ page.meta.get("description", config.site_description) or "" }} | ||||
|  | ||||
|   - &page_icon >- | ||||
|     {{ page.meta.icon or "" }} | ||||
|  | ||||
|   - &logo >- | ||||
|     theme/assets/brand/logos/svg/logo/privacy-guides-logo-notext.svg | ||||
|  | ||||
| # Meta tags | ||||
| tags: | ||||
|   # Open Graph | ||||
|   og:type: website | ||||
|   og:title: *page_title_with_site_name | ||||
|   og:description: *page_description | ||||
|   og:image: "{{ image.url }}" | ||||
|   og:image:type: "{{ image.type }}" | ||||
|   og:image:width: "{{ image.width }}" | ||||
|   og:image:height: "{{ image.height }}" | ||||
|   og:url: "{{ page.canonical_url }}" | ||||
|  | ||||
|   # Twitter | ||||
|   twitter:card: summary_large_image | ||||
|   twitter.title: *page_title_with_site_name | ||||
|   twitter:description: *page_description | ||||
|   twitter:image: "{{ image.url }}" | ||||
|  | ||||
| # ----------------------------------------------------------------------------- | ||||
| # Specification | ||||
| # ----------------------------------------------------------------------------- | ||||
|  | ||||
| # Card size and layers | ||||
| size: { width: 1200, height: 630 } | ||||
| layers: | ||||
|   # Background | ||||
|   - background: | ||||
|       image: *background_image | ||||
|       color: *background_color | ||||
|  | ||||
|   # Page icon | ||||
|   - size: { width: 630, height: 630 } | ||||
|     offset: { x: 570, y: 0 } | ||||
|     icon: | ||||
|       value: *page_icon | ||||
|       color: "#00000033" | ||||
|  | ||||
|   # Logo | ||||
|   - size: { width: 64, height: 64 } | ||||
|     offset: { x: 64, y: 64 } | ||||
|     background: | ||||
|       image: *logo | ||||
|  | ||||
|   # Site name | ||||
|   - size: { width: 768, height: 42 } | ||||
|     offset: { x: 160, y: 78 } | ||||
|     typography: | ||||
|       content: *site_name | ||||
|       color: *color | ||||
|       font: | ||||
|         family: Bagnard | ||||
|         style: Bold | ||||
|  | ||||
|   # Page title | ||||
|   - size: { width: 864, height: 256 } | ||||
|     offset: { x: 62, y: 192 } | ||||
|     typography: | ||||
|       content: *page_title | ||||
|       align: start | ||||
|       color: *color | ||||
|       line: | ||||
|         amount: 3 | ||||
|         height: 1.5 | ||||
|       font: | ||||
|         family: *title_font_family | ||||
|         style: Bold | ||||
|  | ||||
|   # Page description | ||||
|   - size: { width: 864, height: 96 } | ||||
|     offset: { x: 64, y: 480 } | ||||
|     typography: | ||||
|       content: *page_description | ||||
|       align: start | ||||
|       color: *color | ||||
|       line: | ||||
|         amount: 3 | ||||
|         height: 1.5 | ||||
|       font: | ||||
|         family: *font_family | ||||
|         style: Regular | ||||
							
								
								
									
										433
									
								
								config/mkdocs-common.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,433 @@ | ||||
| # Copyright (c) 2022-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. | ||||
|  | ||||
| docs_dir: "../docs" | ||||
| site_url: "https://www.privacyguides.org/" | ||||
| site_dir: "../site" | ||||
|  | ||||
| site_name: Privacy Guides | ||||
| site_description: | ||||
|   !ENV [ | ||||
|     SITE_DESCRIPTION, | ||||
|     "Privacy Guides is your central privacy and security resource to protect yourself online.", | ||||
|   ] | ||||
| edit_uri_template: blob/main/docs/{path}?plain=1 | ||||
|  | ||||
| extra: | ||||
|   generator: false | ||||
|   context: !ENV [CONTEXT, "production"] | ||||
|   deploy: !ENV DEPLOY_ID | ||||
|   privacy_guides: | ||||
|     footer: | ||||
|       intro: | ||||
|         !ENV [ | ||||
|           FOOTER_INTRO, | ||||
|           "Privacy Guides is a non-profit, socially motivated website that provides information for protecting your data security and privacy.", | ||||
|         ] | ||||
|       note: | ||||
|         !ENV [ | ||||
|           FOOTER_NOTE, | ||||
|           "We do not make money from recommending certain products, and we do not use affiliate links.", | ||||
|         ] | ||||
|       copyright: | ||||
|         author: | ||||
|           !ENV [FOOTER_COPYRIGHT_AUTHOR, "Privacy Guides and contributors."] | ||||
|         date: !ENV [FOOTER_COPYRIGHT_DATE, "2019-2024"] | ||||
|       license: | ||||
|         - fontawesome/brands/creative-commons | ||||
|         - fontawesome/brands/creative-commons-by | ||||
|         - fontawesome/brands/creative-commons-nd | ||||
|       analytics: !ENV [FOOTER_ANALYTICS, "Anonymous statistics preferences."] | ||||
|     homepage: | ||||
|       description: | ||||
|         !ENV [ | ||||
|           HOMEPAGE_DESCRIPTION, | ||||
|           "A socially motivated website which provides information about protecting your online data privacy and security.", | ||||
|         ] | ||||
|       hero: | ||||
|         header: | ||||
|           !ENV [HOMEPAGE_HEADER, "The guide to restoring your online privacy."] | ||||
|         subheader: | ||||
|           !ENV [ | ||||
|             HOMEPAGE_SUBHEADER, | ||||
|             "Massive organizations are monitoring your online activities. Privacy Guides is your central privacy and security resource to protect yourself online.", | ||||
|           ] | ||||
|         buttons: | ||||
|           - name: | ||||
|               !ENV [ | ||||
|                 HOMEPAGE_BUTTON_GET_STARTED_NAME, | ||||
|                 "Start Your Privacy Journey", | ||||
|               ] | ||||
|             title: | ||||
|               !ENV [ | ||||
|                 HOMEPAGE_BUTTON_GET_STARTED_TITLE, | ||||
|                 "The first step of your privacy journey", | ||||
|               ] | ||||
|             link: basics/why-privacy-matters/ | ||||
|             class: md-button md-button--primary | ||||
|           - name: !ENV [HOMEPAGE_BUTTON_TOOLS_NAME, "Recommended Tools"] | ||||
|             title: | ||||
|               !ENV [ | ||||
|                 HOMEPAGE_BUTTON_TOOLS_TITLE, | ||||
|                 "Recommended privacy tools, services, and knowledge", | ||||
|               ] | ||||
|             link: tools/ | ||||
|             class: md-button | ||||
|       cta: | ||||
|         - title: | ||||
|             !ENV [ | ||||
|               HOMEPAGE_CTA_TITLE, | ||||
|               "We need you! Here's how to get involved:", | ||||
|             ] | ||||
|           links: | ||||
|             - icon: simple/discourse | ||||
|               name: !ENV [HOMEPAGE_CTA_FORUM_NAME, "Join the forum"] | ||||
|               link: https://discuss.privacyguides.net/ | ||||
|             - icon: simple/mastodon | ||||
|               name: !ENV [HOMEPAGE_CTA_MASTODON_NAME, "Follow us on Mastodon"] | ||||
|               link: https://mastodon.neat.computer/@privacyguides | ||||
|             - icon: simple/github | ||||
|               name: !ENV [HOMEPAGE_CTA_GITHUB_NAME, "Contribute on GitHub"] | ||||
|               link: https://github.com/privacyguides/privacyguides.org | ||||
|             - icon: material/translate | ||||
|               name: !ENV [HOMEPAGE_CTA_TRANSLATE_NAME, "Help translate"] | ||||
|               link: https://crowdin.com/project/privacyguides | ||||
|             - icon: simple/matrix | ||||
|               name: !ENV [HOMEPAGE_CTA_MATRIX_NAME, "Join the Matrix chat"] | ||||
|               link: https://matrix.to/#/#privacyguides:matrix.org | ||||
|             - icon: material/information-outline | ||||
|               name: !ENV [HOMEPAGE_CTA_ABOUT_NAME, "Learn more about us"] | ||||
|               link: about/ | ||||
|             - icon: material/hand-coin | ||||
|               name: !ENV [HOMEPAGE_CTA_DONATE_NAME, "Donate to Privacy Guides"] | ||||
|               link: about/donate/ | ||||
|           description: | ||||
|             !ENV [ | ||||
|               HOMEPAGE_CTA_DESCRIPTION, | ||||
|               "If you spot an error, think a provider should not be listed, notice a qualified provider is missing, believe a browser plugin is no longer the best choice, or uncover any other issue, please let us know.", | ||||
|             ] | ||||
|       rss: | ||||
|         - title: | ||||
|             !ENV [ | ||||
|               HOMEPAGE_RSS_CHANGELOG_TITLE, | ||||
|               "Privacy Guides release changelog", | ||||
|             ] | ||||
|           link: | ||||
|             !ENV [ | ||||
|               HOMEPAGE_RSS_CHANGELOG_LINK, | ||||
|               "https://discuss.privacyguides.net/c/site-development/changelog/9.rss", | ||||
|             ] | ||||
|         - title: !ENV [HOMEPAGE_RSS_BLOG_TITLE, "Privacy Guides blog feed"] | ||||
|           link: | ||||
|             !ENV [ | ||||
|               HOMEPAGE_RSS_BLOG_LINK, | ||||
|               "https://blog.privacyguides.org/feed_rss_created.xml", | ||||
|             ] | ||||
|         - title: | ||||
|             !ENV [HOMEPAGE_RSS_STORIES_TITLE, "Privacy Guides Web Stories feed"] | ||||
|           link: | ||||
|             !ENV [ | ||||
|               HOMEPAGE_RSS_STORIES_LINK, | ||||
|               "https://share.privacyguides.org/web-stories/feed/", | ||||
|             ] | ||||
|         - title: | ||||
|             !ENV [ | ||||
|               HOMEPAGE_RSS_FORUM_TITLE, | ||||
|               "Latest Privacy Guides forum topics", | ||||
|             ] | ||||
|           link: | ||||
|             !ENV [ | ||||
|               HOMEPAGE_RSS_FORUM_LINK, | ||||
|               "https://discuss.privacyguides.net/latest.rss", | ||||
|             ] | ||||
|     translation_notice: | ||||
|       notice: !ENV TRANSLATION_NOTICE | ||||
|       cta: !ENV [TRANSLATION_NOTICE_CTA, "Visit Crowdin"] | ||||
|       language: !ENV LANG_ENGLISH | ||||
|   social: | ||||
|     - icon: simple/mastodon | ||||
|       link: https://mastodon.neat.computer/@privacyguides | ||||
|       name: !ENV [SOCIAL_MASTODON, "Mastodon"] | ||||
|     - icon: simple/matrix | ||||
|       link: https://matrix.to/#/#privacyguides:matrix.org | ||||
|       name: !ENV [SOCIAL_MATRIX, "Matrix"] | ||||
|     - icon: simple/discourse | ||||
|       link: https://discuss.privacyguides.net/ | ||||
|       name: !ENV [SOCIAL_FORUM, "Forum"] | ||||
|     - icon: simple/github | ||||
|       link: https://github.com/privacyguides | ||||
|       name: !ENV [SOCIAL_GITHUB, "GitHub"] | ||||
|     - icon: simple/torbrowser | ||||
|       link: http://www.xoe4vn5uwdztif6goazfbmogh6wh5jc4up35bqdflu6bkdc5cas5vjqd.onion/ | ||||
|       name: !ENV [SOCIAL_TOR_SITE, "Hidden service"] | ||||
|   alternate: | ||||
|     - name: English | ||||
|       link: /en/ | ||||
|       lang: en | ||||
|       icon: https://raw.githubusercontent.com/twitter/twemoji/master/assets/svg/1f1fa-1f1f8.svg | ||||
|     - name: Español | ||||
|       link: /es/ | ||||
|       lang: es | ||||
|       icon: https://raw.githubusercontent.com/twitter/twemoji/master/assets/svg/1f1ea-1f1f8.svg | ||||
|     - name: Français | ||||
|       link: /fr/ | ||||
|       lang: fr | ||||
|       icon: https://raw.githubusercontent.com/twitter/twemoji/master/assets/svg/1f1eb-1f1f7.svg | ||||
|     - name: עִברִית | ||||
|       link: /he/ | ||||
|       lang: he | ||||
|       icon: https://raw.githubusercontent.com/twitter/twemoji/master/assets/svg/1f1ee-1f1f1.svg | ||||
|     - name: Italiano | ||||
|       link: /it/ | ||||
|       lang: it | ||||
|       icon: https://raw.githubusercontent.com/twitter/twemoji/master/assets/svg/1f1ee-1f1f9.svg | ||||
|     - name: Nederlands | ||||
|       link: /nl/ | ||||
|       lang: nl | ||||
|       icon: https://raw.githubusercontent.com/twitter/twemoji/master/assets/svg/1f1f3-1f1f1.svg | ||||
|     - name: 正體中文 | ||||
|       link: /zh-hant/ | ||||
|       lang: zh-Hant | ||||
|       icon: https://raw.githubusercontent.com/twitter/twemoji/master/assets/svg/1f1ed-1f1f0.svg | ||||
|     - name: русский | ||||
|       link: /ru/ | ||||
|       lang: ru | ||||
|       icon: https://raw.githubusercontent.com/twitter/twemoji/master/assets/svg/1f1f7-1f1fa.svg | ||||
|   analytics: | ||||
|     feedback: | ||||
|       title: !ENV [ANALYTICS_FEEDBACK_TITLE, "Was this page helpful?"] | ||||
|       ratings: | ||||
|         - icon: material/emoticon-happy-outline | ||||
|           name: !ENV [ANALYTICS_FEEDBACK_POSITIVE_NAME, "This page was helpful"] | ||||
|           data: 1 | ||||
|           note: | ||||
|             !ENV [ANALYTICS_FEEDBACK_POSITIVE_NOTE, "Thanks for your feedback!"] | ||||
|         - icon: material/emoticon-sad-outline | ||||
|           name: | ||||
|             !ENV [ | ||||
|               ANALYTICS_FEEDBACK_NEGATIVE_NAME, | ||||
|               "This page could be improved", | ||||
|             ] | ||||
|           data: 0 | ||||
|           note: | ||||
|             !ENV [ANALYTICS_FEEDBACK_NEGATIVE_NOTE, "Thanks for your feedback!"] | ||||
|   consent: | ||||
|     title: !ENV [ANALYTICS_CONSENT_TITLE, "Contribute anonymous statistics"] | ||||
|     description: | ||||
|       !ENV [ | ||||
|         ANALYTICS_CONSENT_BODY, | ||||
|         "We use cookies to collect anonymous usage statistics. You can opt out if you wish.", | ||||
|       ] | ||||
|     cookies: | ||||
|       analytics: | ||||
|         name: !ENV [ANALYTICS_COOKIE_UMAMI, "Self-Hosted Analytics"] | ||||
|         checked: true | ||||
|       github: | ||||
|         name: !ENV [ANALYTICS_COOKIE_GITHUB, "GitHub API"] | ||||
|         checked: true | ||||
|     actions: | ||||
|       - reject | ||||
|       - accept | ||||
|       - manage | ||||
|  | ||||
| repo_url: https://github.com/privacyguides/privacyguides.org | ||||
| repo_name: "" | ||||
|  | ||||
| theme: | ||||
|   name: material | ||||
|   language: en | ||||
|   custom_dir: ../theme | ||||
|   logo: ../../theme/assets/brand/logos/svg/logo/privacy-guides-logo-notext-colorbg.svg | ||||
|   font: | ||||
|     text: Public Sans | ||||
|     code: DM Mono | ||||
|   palette: | ||||
|     - media: "(prefers-color-scheme)" | ||||
|       scheme: default | ||||
|       accent: deep purple | ||||
|       toggle: | ||||
|         icon: material/brightness-auto | ||||
|         name: !ENV [THEME_DARK, "Switch to dark mode"] | ||||
|     - media: "(prefers-color-scheme: dark)" | ||||
|       scheme: slate | ||||
|       accent: amber | ||||
|       toggle: | ||||
|         icon: material/brightness-2 | ||||
|         name: !ENV [THEME_LIGHT, "Switch to light mode"] | ||||
|     - media: "(prefers-color-scheme: light)" | ||||
|       scheme: default | ||||
|       accent: deep purple | ||||
|       toggle: | ||||
|         icon: material/brightness-5 | ||||
|         name: !ENV [THEME_AUTO, "Switch to system theme"] | ||||
|   favicon: assets/brand/logos/png/favicon-32x32.png | ||||
|   icon: | ||||
|     repo: simple/github | ||||
|   features: | ||||
|     - navigation.tracking | ||||
|     - navigation.tabs | ||||
|     - navigation.sections | ||||
|     - navigation.expand | ||||
|     - navigation.path | ||||
|     - navigation.indexes | ||||
|     - content.action.edit | ||||
|     - content.tabs.link | ||||
|     - content.tooltips | ||||
|     - search.highlight | ||||
|  | ||||
| extra_css: | ||||
|   - assets/stylesheets/extra.css?v=1 | ||||
| extra_javascript: | ||||
|   - assets/javascripts/randomize-element.js?v=1 | ||||
|   - assets/javascripts/resolution.js?v=1 | ||||
|   - assets/javascripts/feedback.js?v=1 | ||||
|  | ||||
| watch: | ||||
|   - ../theme | ||||
|   - ../includes | ||||
|   - mkdocs-common.yml | ||||
|  | ||||
| plugins: | ||||
|   tags: {} | ||||
|   search: {} | ||||
|   privacy: {} | ||||
|  | ||||
| markdown_extensions: | ||||
|   admonition: {} | ||||
|   pymdownx.details: {} | ||||
|   pymdownx.superfences: | ||||
|     custom_fences: | ||||
|       - name: mermaid | ||||
|         class: mermaid | ||||
|         format: !!python/name:pymdownx.superfences.fence_code_format | ||||
|   pymdownx.tabbed: | ||||
|     alternate_style: true | ||||
|   pymdownx.arithmatex: | ||||
|     generic: true | ||||
|   pymdownx.critic: {} | ||||
|   pymdownx.caret: {} | ||||
|   pymdownx.keys: {} | ||||
|   pymdownx.mark: {} | ||||
|   pymdownx.tilde: {} | ||||
|   pymdownx.snippets: | ||||
|     auto_append: | ||||
|       - includes/abbreviations.en.txt | ||||
|   pymdownx.tasklist: | ||||
|     custom_checkbox: true | ||||
|   attr_list: {} | ||||
|   def_list: {} | ||||
|   md_in_html: {} | ||||
|   meta: {} | ||||
|   abbr: {} | ||||
|   pymdownx.emoji: | ||||
|     emoji_index: !!python/name:material.extensions.emoji.twemoji | ||||
|     emoji_generator: !!python/name:material.extensions.emoji.to_svg | ||||
|   tables: {} | ||||
|   footnotes: {} | ||||
|   toc: | ||||
|     permalink: true | ||||
|     toc_depth: 4 | ||||
|  | ||||
| nav: | ||||
|   - !ENV [NAV_HOME, "Home"]: "index.md" | ||||
|   - !ENV [NAV_KNOWLEDGE_BASE, "Knowledge Base"]: | ||||
|       - "basics/why-privacy-matters.md" | ||||
|       - "basics/threat-modeling.md" | ||||
|       - "basics/common-threats.md" | ||||
|       - "basics/common-misconceptions.md" | ||||
|       - "basics/account-creation.md" | ||||
|       - "basics/account-deletion.md" | ||||
|       - !ENV [NAV_TECHNOLOGY_ESSENTIALS, "Technology Essentials"]: | ||||
|           - "basics/passwords-overview.md" | ||||
|           - "basics/multi-factor-authentication.md" | ||||
|           - "basics/email-security.md" | ||||
|           - "basics/vpn-overview.md" | ||||
|       - !ENV [NAV_ADVANCED_TOPICS, "Advanced Topics"]: | ||||
|           - "advanced/dns-overview.md" | ||||
|           - "advanced/tor-overview.md" | ||||
|           - "advanced/payments.md" | ||||
|           - "advanced/communication-network-types.md" | ||||
|       - !ENV [NAV_OPERATING_SYSTEMS, "Operating Systems"]: | ||||
|           - "os/android-overview.md" | ||||
|           - "os/ios-overview.md" | ||||
|           - "os/linux-overview.md" | ||||
|           - "os/macos-overview.md" | ||||
|           - "os/qubes-overview.md" | ||||
|       - kb-archive.md | ||||
|   - !ENV [NAV_RECOMMENDATIONS, "Recommendations"]: | ||||
|       - "tools.md" | ||||
|       - !ENV [NAV_INTERNET_BROWSING, "Internet Browsing"]: | ||||
|           - "tor.md" | ||||
|           - "desktop-browsers.md" | ||||
|           - "mobile-browsers.md" | ||||
|           - "browser-extensions.md" | ||||
|       - !ENV [NAV_PROVIDERS, "Providers"]: | ||||
|           - "cloud.md" | ||||
|           - "dns.md" | ||||
|           - "email-aliasing.md" | ||||
|           - "email.md" | ||||
|           - "financial-services.md" | ||||
|           - "photo-management.md" | ||||
|           - "search-engines.md" | ||||
|           - "vpn.md" | ||||
|       - !ENV [NAV_SOFTWARE, "Software"]: | ||||
|           - "calendar.md" | ||||
|           - "cryptocurrency.md" | ||||
|           - "data-redaction.md" | ||||
|           - "email-clients.md" | ||||
|           - "encryption.md" | ||||
|           - "file-sharing.md" | ||||
|           - "frontends.md" | ||||
|           - "multi-factor-authentication.md" | ||||
|           - "news-aggregators.md" | ||||
|           - "notebooks.md" | ||||
|           - "passwords.md" | ||||
|           - "productivity.md" | ||||
|           - "real-time-communication.md" | ||||
|       - !ENV [NAV_OPERATING_SYSTEMS, "Operating Systems"]: | ||||
|           - "android.md" | ||||
|           - "desktop.md" | ||||
|           - "router.md" | ||||
|       - !ENV [NAV_ADVANCED, "Advanced"]: | ||||
|           - "device-integrity.md" | ||||
|   - !ENV [NAV_ABOUT, "About"]: | ||||
|       - "about/index.md" | ||||
|       - "about/criteria.md" | ||||
|       - "about/notices.md" | ||||
|       - "about/privacy-policy.md" | ||||
|       - "about/statistics.md" | ||||
|       - !ENV [NAV_COMMUNITY, "Community"]: | ||||
|           - "about/donate.md" | ||||
|           - !ENV [NAV_ONLINE_SERVICES, "Online Services"]: "about/services.md" | ||||
|           - !ENV [NAV_CODE_OF_CONDUCT, "Code of Conduct"]: "CODE_OF_CONDUCT.md" | ||||
|           - "about/privacytools.md" | ||||
|       - !ENV [NAV_CONTRIBUTING, "Contributing"]: | ||||
|           - !ENV [NAV_WRITING_GUIDE, "Writing Guide"]: | ||||
|               - "meta/writing-style.md" | ||||
|               - "meta/admonitions.md" | ||||
|               - "meta/brand.md" | ||||
|               - "meta/translations.md" | ||||
|           - !ENV [NAV_TECHNICAL_GUIDES, "Technical Guides"]: | ||||
|               - "meta/uploading-images.md" | ||||
|               - "meta/git-recommendations.md" | ||||
|   - !ENV [NAV_CHANGELOG, "Changelog"]: | ||||
|       "https://github.com/privacyguides/privacyguides.org/releases" | ||||
|   - !ENV [NAV_FORUM, "Forum"]: "https://discuss.privacyguides.net/" | ||||
|   - !ENV [NAV_BLOG, "Blog"]: "https://blog.privacyguides.org/" | ||||
							
								
								
									
										70
									
								
								config/mkdocs-offline.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,70 @@ | ||||
| # Copyright (c) 2023-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. | ||||
|  | ||||
| INHERIT: mkdocs-common.yml | ||||
|  | ||||
| # Disable any GitHub integrations | ||||
| repo_url: "" | ||||
| edit_uri_template: "" | ||||
|  | ||||
| extra: | ||||
|   # Disable language switcher | ||||
|   alternate: false | ||||
|   offline: true | ||||
|   privacy_guides: | ||||
|     homepage: | ||||
|       hero: | ||||
|         buttons: | ||||
|           - name: | ||||
|               !ENV [ | ||||
|                 HOMEPAGE_BUTTON_GET_STARTED_NAME, | ||||
|                 "Start Your Privacy Journey", | ||||
|               ] | ||||
|             title: | ||||
|               !ENV [ | ||||
|                 HOMEPAGE_BUTTON_GET_STARTED_TITLE, | ||||
|                 "The first step of your privacy journey", | ||||
|               ] | ||||
|             link: basics/why-privacy-matters.html | ||||
|             class: md-button md-button--primary | ||||
|           - name: !ENV [HOMEPAGE_BUTTON_TOOLS_NAME, "Recommended Tools"] | ||||
|             title: | ||||
|               !ENV [ | ||||
|                 HOMEPAGE_BUTTON_TOOLS_TITLE, | ||||
|                 "Recommended privacy tools, services, and knowledge", | ||||
|               ] | ||||
|             link: tools.html | ||||
|             class: md-button | ||||
|  | ||||
| theme: | ||||
|   features: | ||||
|     - navigation.tabs | ||||
|     - navigation.sections | ||||
|     - navigation.indexes | ||||
|     - content.tabs.link | ||||
|     - content.tooltips | ||||
|     - search.highlight | ||||
|  | ||||
| plugins: | ||||
|   offline: | ||||
|     enabled: true | ||||
|   social: | ||||
|     enabled: false | ||||
| # Edit the offline-mode navbar in mkdocs-common.yml | ||||
							
								
								
									
										29
									
								
								config/mkdocs-production.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,29 @@ | ||||
| INHERIT: mkdocs-common.yml | ||||
|  | ||||
| plugins: | ||||
|   macros: {} | ||||
|   meta: {} | ||||
|   git-committers: | ||||
|     enabled: !ENV [GITCOMMITTERS, PRODUCTION, NETLIFY, false] | ||||
|     repository: privacyguides/privacyguides.org | ||||
|     branch: main | ||||
|   git-revision-date-localized: | ||||
|     enabled: !ENV [GITREVISIONDATE, PRODUCTION, NETLIFY, false] | ||||
|     exclude: | ||||
|       - index.md | ||||
|     fallback_to_build_date: true | ||||
|   optimize: | ||||
|     enabled: !ENV [OPTIMIZE, PRODUCTION, NETLIFY, false] | ||||
|   typeset: {} | ||||
|   social: | ||||
|     cards: !ENV [CARDS, PRODUCTION, NETLIFY, true] | ||||
|     cards_dir: assets/img/social | ||||
|     cards_layout_dir: config/layouts | ||||
|     cards_layout: page | ||||
|     # cards_layout: pride | ||||
|  | ||||
| markdown_extensions: | ||||
|   material.extensions.preview: | ||||
|     sources: | ||||
|       exclude: | ||||
|         - tools.md | ||||
							
								
								
									
										27
									
								
								config/mkdocs.en.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,27 @@ | ||||
| # Copyright (c) 2022-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. | ||||
|  | ||||
| INHERIT: !ENV [MKDOCS_INHERIT, mkdocs-common.yml] | ||||
| site_url: "https://www.privacyguides.org/en/" | ||||
| site_dir: "../site/en" | ||||
|  | ||||
| theme: | ||||
|   # ENGLISH ONLY: this logo needs to be set separately because the relative path is different | ||||
|   logo: ../theme/assets/brand/logos/svg/logo/privacy-guides-logo-notext-colorbg.svg | ||||
							
								
								
									
										34
									
								
								config/mkdocs.es.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,34 @@ | ||||
| # Copyright (c) 2022-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. | ||||
|  | ||||
| INHERIT: !ENV [MKDOCS_INHERIT, mkdocs-common.yml] | ||||
| docs_dir: "../i18n/es" | ||||
| site_url: "https://www.privacyguides.org/es/" | ||||
| site_dir: "../site/es" | ||||
|  | ||||
| edit_uri_template: https://github.com/privacyguides/i18n/blob/main/i18n/es/{path}?plain=1 | ||||
|  | ||||
| theme: | ||||
|   language: es | ||||
|  | ||||
| markdown_extensions: | ||||
|   pymdownx.snippets: | ||||
|     auto_append: | ||||
|       - includes/abbreviations.es.txt | ||||
							
								
								
									
										34
									
								
								config/mkdocs.fr.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,34 @@ | ||||
| # Copyright (c) 2022-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. | ||||
|  | ||||
| INHERIT: !ENV [MKDOCS_INHERIT, mkdocs-common.yml] | ||||
| docs_dir: "../i18n/fr" | ||||
| site_url: "https://www.privacyguides.org/fr/" | ||||
| site_dir: "../site/fr" | ||||
|  | ||||
| edit_uri_template: https://github.com/privacyguides/i18n/blob/main/i18n/fr/{path}?plain=1 | ||||
|  | ||||
| theme: | ||||
|   language: fr | ||||
|  | ||||
| markdown_extensions: | ||||
|   pymdownx.snippets: | ||||
|     auto_append: | ||||
|       - includes/abbreviations.fr.txt | ||||
							
								
								
									
										41
									
								
								config/mkdocs.he.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,41 @@ | ||||
| # Copyright (c) 2022-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. | ||||
|  | ||||
| INHERIT: !ENV [MKDOCS_INHERIT, mkdocs-common.yml] | ||||
| docs_dir: "../i18n/he" | ||||
| site_url: "https://www.privacyguides.org/he/" | ||||
| site_dir: "../site/he" | ||||
|  | ||||
| edit_uri_template: https://github.com/privacyguides/i18n/blob/main/i18n/he/{path}?plain=1 | ||||
|  | ||||
| extra_css: | ||||
|   - assets/stylesheets/extra.css?v=3.2.0 | ||||
|   - assets/stylesheets/lang-he.css?v=3.4.0 | ||||
|  | ||||
| theme: | ||||
|   language: he | ||||
|   font: | ||||
|     text: Open Sans | ||||
|     code: Cousine | ||||
|  | ||||
| markdown_extensions: | ||||
|   pymdownx.snippets: | ||||
|     auto_append: | ||||
|       - includes/abbreviations.he.txt | ||||
							
								
								
									
										34
									
								
								config/mkdocs.it.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,34 @@ | ||||
| # Copyright (c) 2022-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. | ||||
|  | ||||
| INHERIT: !ENV [MKDOCS_INHERIT, mkdocs-common.yml] | ||||
| docs_dir: "../i18n/it" | ||||
| site_url: "https://www.privacyguides.org/it/" | ||||
| site_dir: "../site/it" | ||||
|  | ||||
| edit_uri_template: https://github.com/privacyguides/i18n/blob/main/i18n/it/{path}?plain=1 | ||||
|  | ||||
| theme: | ||||
|   language: it | ||||
|  | ||||
| markdown_extensions: | ||||
|   pymdownx.snippets: | ||||
|     auto_append: | ||||
|       - includes/abbreviations.it.txt | ||||
							
								
								
									
										34
									
								
								config/mkdocs.nl.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,34 @@ | ||||
| # Copyright (c) 2022-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. | ||||
|  | ||||
| INHERIT: !ENV [MKDOCS_INHERIT, mkdocs-common.yml] | ||||
| docs_dir: "../i18n/nl" | ||||
| site_url: "https://www.privacyguides.org/nl/" | ||||
| site_dir: "../site/nl" | ||||
|  | ||||
| edit_uri_template: https://github.com/privacyguides/i18n/blob/main/i18n/nl/{path}?plain=1 | ||||
|  | ||||
| theme: | ||||
|   language: nl | ||||
|  | ||||
| markdown_extensions: | ||||
|   pymdownx.snippets: | ||||
|     auto_append: | ||||
|       - includes/abbreviations.nl.txt | ||||
							
								
								
									
										38
									
								
								config/mkdocs.ru.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,38 @@ | ||||
| # Copyright (c) 2022-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. | ||||
|  | ||||
| INHERIT: !ENV [MKDOCS_INHERIT, mkdocs-common.yml] | ||||
| docs_dir: "../i18n/ru" | ||||
| site_url: "https://www.privacyguides.org/ru/" | ||||
| site_dir: "../site/ru" | ||||
|  | ||||
| edit_uri_template: https://github.com/privacyguides/i18n/blob/main/i18n/ru/{path}?plain=1 | ||||
|  | ||||
| extra_css: | ||||
|   - assets/stylesheets/extra.css?v=3.2.0 | ||||
|   - assets/stylesheets/lang-ru.css?v=3.13.0 | ||||
|  | ||||
| theme: | ||||
|   language: ru | ||||
|  | ||||
| markdown_extensions: | ||||
|   pymdownx.snippets: | ||||
|     auto_append: | ||||
|       - includes/abbreviations.ru.txt | ||||
							
								
								
									
										41
									
								
								config/mkdocs.zh-Hant.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,41 @@ | ||||
| # Copyright (c) 2022-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. | ||||
|  | ||||
| INHERIT: !ENV [MKDOCS_INHERIT, mkdocs-common.yml] | ||||
| docs_dir: "../i18n/zh-Hant" | ||||
| site_url: "https://www.privacyguides.org/zh-Hant/" | ||||
| site_dir: "../site/zh-Hant" | ||||
|  | ||||
| edit_uri_template: https://github.com/privacyguides/i18n/blob/main/i18n/zh-Hant/{path}?plain=1 | ||||
|  | ||||
| extra_css: | ||||
|   - assets/stylesheets/extra.css?v=3.2.0 | ||||
|   - assets/stylesheets/lang-zh-Hant.css?v=3.13.0 | ||||
|  | ||||
| theme: | ||||
|   language: zh-Hant | ||||
|   font: | ||||
|     text: Noto Sans TC | ||||
|     code: Noto Sans TC | ||||
|  | ||||
| markdown_extensions: | ||||
|   pymdownx.snippets: | ||||
|     auto_append: | ||||
|       - includes/abbreviations.zh-Hant.txt | ||||
							
								
								
									
										33
									
								
								crowdin.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,33 @@ | ||||
| # Copyright (c) 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. | ||||
|  | ||||
| #checkov:skip=CKV_SECRET_6:obviously a variable name and not a secret | ||||
| api_token_env: CROWDIN_PERSONAL_TOKEN | ||||
| project_id: "509862" | ||||
| "preserve_hierarchy": true | ||||
| files: | ||||
|   - source: "/docs/**/*.*" | ||||
|     translation: "/i18n/%two_letters_code%/**/%file_name%.%file_extension%" | ||||
|     skip_untranslated_files: false | ||||
|   - source: "/includes/*.en.*" | ||||
|     translation: "/includes/%file_name%.%two_letters_code%.%file_extension%" | ||||
|     translation_replace: | ||||
|       "en.": "" | ||||
|     skip_untranslated_files: false | ||||
							
								
								
									
										53
									
								
								docs/CODE_OF_CONDUCT.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,53 @@ | ||||
| # Community Code of Conduct | ||||
|  | ||||
| **We pledge** to make our community a harassment-free experience for everyone. | ||||
|  | ||||
| **We strive** to create a positive environment, using welcoming and inclusive language, and being respectful of the viewpoints of others. | ||||
|  | ||||
| **We do not allow** inappropriate or otherwise unacceptable behavior, such as sexualized language, trolling and insulting comments, or otherwise promoting intolerance or harassment. | ||||
|  | ||||
| ## Community Standards | ||||
|  | ||||
| What we expect from members of our communities: | ||||
|  | ||||
| 1. **Do not spread misinformation** | ||||
|  | ||||
|       We are creating an evidence-based educational community around information privacy and security, not an information home for conspiracy theories. For example, when making a claim that a certain piece of software is malicious or that certain telemetry data is privacy invasive, explain in detail what is collected and how it collected. Claims of this nature must be backed by technical evidence. | ||||
|  | ||||
| 2. **Do not abuse our willingness to help** | ||||
|  | ||||
|       Our community members are not free tech support. We are happy to help with specific steps for your privacy journey, if you are willing to put in effort. We are not obligated to answer endless, repetitive questions about general computer problems solvable with a simple internet search. **Do not** become a [help vampire](https://slash7.com/2006/12/22/vampires). | ||||
|  | ||||
| 3. **Behave in a positive and constructive manner** | ||||
|  | ||||
|       Examples of behavior that contributes to a positive environment for our community include: | ||||
|  | ||||
|       - Being respectful of differing opinions, viewpoints, and experiences. | ||||
|       - Demonstrating empathy and kindness toward others. | ||||
|       - Focusing on what is best not just for us as overseers, but for the overall community. | ||||
|       - Giving and gracefully accepting constructive feedback within our community while growing and improving. | ||||
|       - Operating with a communal mindset at all times. | ||||
|  | ||||
| ## Unacceptable Behavior | ||||
|  | ||||
| The following behaviors are considered harassment and are unacceptable within our community: | ||||
|  | ||||
| - Any other conduct which would reasonably be considered inappropriate in a professional setting. | ||||
| - Public and/or private harassment of any kind. | ||||
| - Publishing others' private information, such as a physical address and/or an email address, without their explicit permission. | ||||
| - The use of sexualized language or imagery, and sexual attention or advances of any kind. | ||||
| - Trolling, insulting and/or derogatory comments, including personal or political attacks. | ||||
|  | ||||
| ## Scope | ||||
|  | ||||
| Our Code of Conduct applies within all project spaces, as well as when an individual is representing the Privacy Guides project in other communities. | ||||
|  | ||||
| We are responsible for clarifying the standards of our community and have the right to remove or alter the comments of those participating within our community, as necessary and at our discretion. | ||||
|  | ||||
| ## Contact | ||||
|  | ||||
| If you observe a problem on a platform like Matrix or Reddit, please contact our moderators on that platform via chat, direct message, or any designated "Modmail" system. | ||||
|  | ||||
| If you have a problem elsewhere, or a problem that our community moderators are unable to resolve, reach out to `jonah@privacyguides.org` and/or `dngray@privacyguides.org`. | ||||
|  | ||||
| All community leaders are obligated to respect the privacy and security of reporters for all incidents. | ||||
							
								
								
									
										32
									
								
								docs/about/criteria.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,32 @@ | ||||
| --- | ||||
| title: General Criteria | ||||
| --- | ||||
|  | ||||
| Below are some general priorities we consider for all submissions to Privacy Guides. Each category will have additional requirements for inclusion. | ||||
|  | ||||
| - **Security**: Tools should follow security best-practices wherever applicable. | ||||
| - **Source Availability**: Open-source projects are generally preferred over equivalent proprietary alternatives. | ||||
| - **Cross-Platform Availability**: We typically prefer recommendations to be cross-platform, to avoid vendor lock-in. | ||||
| - **Active Development**: The tools that we recommend should be actively developed, unmaintained projects will be removed in most cases. | ||||
| - **Usability**: Tools should be accessible to most computer users, an overly technical background should not be required. | ||||
| - **Documentation**: Tools should have clear and extensive documentation for use. | ||||
|  | ||||
| ## Financial Disclosure | ||||
|  | ||||
| We do not make money from recommending certain products, we do not use affiliate links, and we do not provide special consideration to project donors. | ||||
|  | ||||
| ## Developer Self-Submissions | ||||
|  | ||||
| We have these requirements in regard to developers which wish to submit their project or software for consideration. | ||||
|  | ||||
| - Must disclose affiliation, i.e. your position within the project being submitted. | ||||
|  | ||||
| - Must have a security whitepaper if it is a project that involves handling of sensitive information like a messenger, password manager, encrypted cloud storage, etc. | ||||
|     - Third party audit status. We want to know if you have one, or have one planned. If possible please mention who will be conducting the audit. | ||||
|  | ||||
| - Must explain what the project brings to the table in regard to privacy. | ||||
|     - Does it solve any new problem? | ||||
|     - Why should anyone use it over the alternatives? | ||||
|  | ||||
| - Must state what the exact threat model is with their project. | ||||
|     - It should be clear to potential users what the project can provide, and what it cannot. | ||||
							
								
								
									
										40
									
								
								docs/about/donate.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,40 @@ | ||||
| --- | ||||
| title: Supporting Us | ||||
| --- | ||||
| <!-- markdownlint-disable MD036 --> | ||||
| It takes a lot of [people](https://github.com/privacyguides/privacyguides.org/graphs/contributors) and [work](https://github.com/privacyguides/privacyguides.org/pulse/monthly) to keep Privacy Guides up to date and spreading the word about privacy and mass surveillance. If you like what we do, consider getting involved by [editing the site](https://github.com/privacyguides/privacyguides.org) or [contributing translations](https://crowdin.com/project/privacyguides). | ||||
|  | ||||
| <div class="admonition failure" markdown> | ||||
| <p class="admonition-title">Donation Information</p> | ||||
|  | ||||
| Unfortunately, Open Collective Foundation (our long-time fiscal host) announced they are dissolving their operations and can no longer support us or any project they host. Thus, we have no way to accept donations at this time. We are looking into ways to move forward from a legal perspective, but in the meantime any non-monetary contribution you can provide would be greatly appreciated. | ||||
|  | ||||
| </div> | ||||
|  | ||||
| Another option to support us is by buying our merchandise from HelloTux. We get a small commission for each item sold, and you get a quality product to show for it. | ||||
|  | ||||
| [Buy on HelloTux.com](https://hellotux.com/privacyguides){ class="md-button" } | ||||
|  | ||||
| Thank you to all those who support our mission! :heart: | ||||
|  | ||||
| ## How We Use Donations | ||||
|  | ||||
| Privacy Guides is a **non-profit** organization. We use donations for a variety of purposes, including: | ||||
|  | ||||
| **Domain Registrations** | ||||
|  | ||||
| :   We have a few domain names like `privacyguides.org` which cost us around $10 yearly to maintain their registration. | ||||
|  | ||||
| **Web Hosting** | ||||
|  | ||||
| :   Traffic to this website uses hundreds of gigabytes of data per month, we use a variety of service providers to keep up with this traffic. | ||||
|  | ||||
| **Online Services** | ||||
|  | ||||
| :   We host [internet services](https://privacyguides.net) for testing and showcasing different privacy-products we like and [recommend](../tools.md). Some of which are made publicly available for our community's use (SearXNG, Tor, etc.), and some are provided for our team members (email, etc.). | ||||
|  | ||||
| **Product Purchases** | ||||
|  | ||||
| :   We occasionally purchase products and services for the purposes of testing our [recommended tools](../tools.md). | ||||
|  | ||||
| We are still working with our fiscal host (the Open Collective Foundation) to receive cryptocurrency donations, at the moment the accounting is unfeasible for many smaller transactions, but this should change in the future. In the meantime, if you wish to make a sizable (> $100) cryptocurrency donation, please reach out to [jonah@privacyguides.org](mailto:jonah@privacyguides.org). | ||||
							
								
								
									
										133
									
								
								docs/about/index.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,133 @@ | ||||
| --- | ||||
| title: "About Privacy Guides" | ||||
| description: Privacy Guides is a socially motivated website that provides information for protecting your data security and privacy. | ||||
| schema: | ||||
|   "@context": https://schema.org | ||||
|   "@type": Organization | ||||
|   "@id": https://www.privacyguides.org/ | ||||
|   name: Privacy Guides | ||||
|   url: https://www.privacyguides.org/en/about/ | ||||
|   logo: https://www.privacyguides.org/en/assets/brand/logos/png/square/pg-yellow.png | ||||
|   sameAs: | ||||
|     - https://twitter.com/privacy_guides | ||||
|     - https://github.com/privacyguides | ||||
|     - https://www.wikidata.org/wiki/Q111710163 | ||||
|     - https://opencollective.com/privacyguides | ||||
|     - https://www.youtube.com/@privacyguides | ||||
|     - https://mastodon.neat.computer/@privacyguides | ||||
| --- | ||||
| { align=right } | ||||
|  | ||||
| **Privacy Guides** is a socially motivated website that provides [information](/kb) 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](https://discuss.privacyguides.net/g/team) and contributors. Our website is free of advertisements and not affiliated with any of the listed providers. | ||||
|  | ||||
| [:octicons-home-16:](https://www.privacyguides.org){ .card-link title=Homepage } | ||||
| [:octicons-code-16:](https://github.com/privacyguides/privacyguides.org){ .card-link title="Source Code" } | ||||
| [:octicons-heart-16:](donate.md){ .card-link title=Contribute } | ||||
|  | ||||
| > To find [privacy-focused alternative] apps, check out sites like Good Reports and **Privacy Guides**, which list privacy-focused apps in a variety of categories, notably including email providers (usually on paid plans) that aren’t run by the big tech companies. | ||||
|  | ||||
| — [New York Times](https://nytimes.com/wirecutter/guides/online-security-social-media-privacy) | ||||
|  | ||||
| > If you're looking for a new VPN, you can go to the discount code of just about any podcast. If you are looking for a **good** VPN, you need professional help. The same goes for email clients, browsers, operating systems and password managers. How do you know which of these is the best, most privacy-friendly option? For that there is **Privacy Guides**, a platform on which a number of volunteers search day in, day out for the best privacy-friendly tools to use on the internet. | ||||
|  | ||||
| — [Tweakers.net](https://tweakers.net/reviews/10568/op-zoek-naar-privacyvriendelijke-tools-niek-de-wilde-van-privacy-guides.html) [Translated from Dutch] | ||||
|  | ||||
| Also featured on: [Ars Technica](https://arstechnica.com/gadgets/2022/02/is-firefox-ok), [Wirecutter](https://nytimes.com/wirecutter/guides/practical-guide-to-securing-windows-pc) [[2](https://nytimes.com/wirecutter/guides/practical-guide-to-securing-your-mac)], [NPO Radio 1](https://nporadio1.nl/nieuws/binnenland/8eaff3a2-8b29-4f63-9b74-36d2b28b1fe1/ooit-online-eens-wat-doms-geplaatst-ga-jezelf-eens-googlen-en-kijk-dan-wat-je-tegenkomt), and [Wired](https://wired.com/story/firefox-mozilla-2022). | ||||
|  | ||||
| ## History | ||||
|  | ||||
| Privacy Guides was launched in September 2021 as a continuation of the [defunct](privacytools.md) "PrivacyTools" open-source educational project. We recognized the importance of independent, criteria-focused product recommendations and general knowledge in the privacy space, which is why we needed to preserve the work that had been created by so many contributors since 2015 and make sure that information had a stable home on the web indefinitely. | ||||
|  | ||||
| In 2022, we completed the transition of our main website framework from Jekyll to MkDocs, using the `mkdocs-material` documentation software. This change made open-source contributions to our site significantly easier for outsiders, because instead of needing to know complicated syntax to write posts effectively, contributing is now as easy as writing a standard Markdown document. | ||||
|  | ||||
| We additionally launched our new discussion forum at [discuss.privacyguides.net](https://discuss.privacyguides.net) as a community platform to share ideas and ask questions about our mission. This augments our existing community on Matrix, and replaced our previous GitHub Discussions platform, decreasing our reliance on proprietary discussion platforms. | ||||
|  | ||||
| So far in 2023 we've launched international translations of our website in [French](/fr/), [Hebrew](/he/), and [Dutch](/nl/), with more languages on the way, made possible by our excellent translation team on [Crowdin](https://crowdin.com/project/privacyguides). We plan to continue carrying forward our mission of outreach and education, and finding ways to more clearly highlight the dangers of a lack of privacy awareness in the modern digital age, and the prevalence and harms of security breaches across the technology industry. | ||||
|  | ||||
| ## Our Team | ||||
| <!-- markdownlint-disable MD030 --> | ||||
|  | ||||
| <div class="grid cards" markdown> | ||||
| <!--  Every team member should have a unique emoji. | ||||
|       Team member cards should include ONLY the following links: | ||||
|       - Discourse Profile | ||||
|       - ONE Link of team member's choice | ||||
|       - Email if applicable | ||||
|       This is to keep it fair and not spammy, especially as we grow. | ||||
| --> | ||||
|  | ||||
| -   :robot:{ .lg .middle } **@jonah** | ||||
|  | ||||
|     --- | ||||
|  | ||||
|     :material-text-account: Founder | ||||
|  | ||||
|     [:material-account: Profile](https://discuss.privacyguides.net/u/jonah) | ||||
|  | ||||
|     [:material-home: Homepage](https://www.jonaharagon.com) | ||||
|  | ||||
|     [:material-email: Email](mailto:jonah@privacyguides.org) | ||||
|  | ||||
| -   :cactus:{ .lg .middle } **@niek-de-wilde** | ||||
|  | ||||
|     --- | ||||
|  | ||||
|     :material-text-account: Founder | ||||
|  | ||||
|     [:material-account: Profile](https://discuss.privacyguides.net/u/Niek-de-Wilde) | ||||
|  | ||||
|     [:simple-mastodon: Mastodon](https://mastodon.social/@blacklight447 "@blacklight447@mastodon.social"){rel=me} | ||||
|  | ||||
|     [:material-email: Email](mailto:niekdewilde@privacyguides.org) | ||||
|  | ||||
| -   :polar_bear:{ .lg .middle } **@dngray** | ||||
|  | ||||
|     --- | ||||
|  | ||||
|     :material-text-account: Founder | ||||
|  | ||||
|     [:material-account: Profile](https://discuss.privacyguides.net/u/dngray) | ||||
|  | ||||
|     [:simple-mastodon: Mastodon](https://mastodon.social/@dngray "@dngray@mastodon.social"){rel=me} | ||||
|  | ||||
|     [:material-email: Email](mailto:dngray@privacyguides.org) | ||||
|  | ||||
| -   :detective:{ .lg .middle } **@freddy** | ||||
|  | ||||
|     --- | ||||
|  | ||||
|     :material-text-account: Founder | ||||
|  | ||||
|     [:material-account: Profile](https://discuss.privacyguides.net/u/freddy) | ||||
|  | ||||
|     [:simple-mastodon: Mastodon](https://social.lol/@freddy "@freddy@social.lol"){rel=me} | ||||
|  | ||||
|     [:material-email: Email](mailto:freddy@privacyguides.org) | ||||
|  | ||||
| -   :smirk_cat:{ .lg .middle } **@olivia** | ||||
|  | ||||
|     --- | ||||
|  | ||||
|     :material-text-account: Founder | ||||
|  | ||||
|     [:material-account: Profile](https://discuss.privacyguides.net/u/olivia) | ||||
|  | ||||
|     [:simple-mastodon: Mastodon](https://mastodon.neat.computer/@oliviablob "@oliviablob@neat.computer"){rel=me} | ||||
|  | ||||
| </div> | ||||
|  | ||||
| Additionally, [many people](https://github.com/privacyguides/privacyguides.org/graphs/contributors) have made contributions to the project. You can too, we're open source on GitHub, and accepting translation suggestions on [Crowdin](https://crowdin.com/project/privacyguides). | ||||
|  | ||||
| Our team members review all changes made to the website and handle administrative duties such as web hosting and financials, however they do not personally profit from any contributions made to this site. Donations to Privacy Guides are generally tax-deductible in the United States. | ||||
|  | ||||
| ## Site License | ||||
|  | ||||
| <div class="admonition danger" markdown> | ||||
|  | ||||
| The following is a human-readable summary of (and not a substitute for) the [license](/license). | ||||
|  | ||||
| </div> | ||||
|  | ||||
| :fontawesome-brands-creative-commons: :fontawesome-brands-creative-commons-by: :fontawesome-brands-creative-commons-nd: Unless otherwise noted, the original content on this website is made available under the [Creative Commons Attribution-NoDerivatives 4.0 International Public License](https://github.com/privacyguides/privacyguides.org/blob/main/LICENSE). This means that you are free to copy and redistribute the material in any medium or format for any purpose, even commercially; as long as you give appropriate credit to `Privacy Guides (www.privacyguides.org)` and provide a link to the license. You may do so in any reasonable manner, but not in any way that suggests Privacy Guides endorses you or your use. If you remix, transform, or build upon the content of this website, you may not distribute the modified material. | ||||
|  | ||||
| This license is in place to prevent people from sharing our work without giving proper credit, and to prevent people from modifying our work in a way that could be used to mislead people. If you find the terms of this license too restrictive for the project you're working on, please reach out to us at `jonah@privacyguides.org`. We are happy to provide alternative licensing options for well-intentioned projects in the privacy space! | ||||
							
								
								
									
										51
									
								
								docs/about/notices.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,51 @@ | ||||
| --- | ||||
| title: "Notices and Disclaimers" | ||||
| --- | ||||
|  | ||||
| ## Legal Disclaimer | ||||
|  | ||||
| Privacy Guides is not a law firm. As such, the Privacy Guides website and contributors are not providing legal advice. The material and recommendations in our website and guides do not constitute legal advice nor does contributing to the website or communicating with Privacy Guides or other contributors about our website create an attorney-client relationship. | ||||
|  | ||||
| Running this website, like any human endeavor, involves uncertainty and trade-offs. We hope this website helps, but it may include mistakes and can’t address every situation. If you have any questions about your situation, we encourage you to do your own research, seek out other experts, and engage in discussions with the Privacy Guides community. If you have any legal questions, you should consult with your own legal counsel before moving forward. | ||||
|  | ||||
| Privacy Guides is an open-source project contributed to under licenses that include terms that, for the protection of the website and its contributors, make clear that the Privacy Guides project and website is offered "as-is", without warranty, and disclaiming liability for damages resulting from using the website or any recommendations contained within. Privacy Guides does not warrant or make any representations concerning the accuracy, likely results, or reliability of the use of the materials on the website or otherwise relating to such materials on the website or on any third-party sites linked on this site. | ||||
|  | ||||
| Privacy Guides additionally does not warrant that this website will be constantly available, or available at all. | ||||
|  | ||||
| ## Licensing Overview | ||||
|  | ||||
| <div class="admonition danger" markdown> | ||||
|  | ||||
| The following is a human-readable summary of (and not a substitute for) the [license](/license). | ||||
|  | ||||
| </div> | ||||
|  | ||||
| Unless otherwise noted, all **content** on this website is made available under the terms of the [Creative Commons Attribution-NoDerivatives 4.0 International Public License](https://github.com/privacyguides/privacyguides.org/blob/main/LICENSE). The underlying **source code** used to generate this website and display that content is released under the [MIT License](https://github.com/privacyguides/privacyguides.org/tree/main/LICENSE-CODE). | ||||
|  | ||||
| This does not include third-party code embedded in this repository, or code where a superseding license is otherwise noted. The following are notable examples, but this list may not be all-inclusive: | ||||
|  | ||||
| * The [Bagnard](https://github.com/privacyguides/brand/tree/67166ed8b641d8ac1837d0b75329e02ed4056704/fonts/Bagnard) heading font is licensed under the [SIL Open Font License 1.1](https://github.com/privacyguides/brand/blob/67166ed8b641d8ac1837d0b75329e02ed4056704/fonts/Bagnard/LICENSE.txt). | ||||
| * The [Public Sans](https://github.com/privacyguides/brand/tree/67166ed8b641d8ac1837d0b75329e02ed4056704/fonts/Public%20Sans) font used for most text on the site is licensed under the terms detailed [here](https://github.com/privacyguides/brand/blob/67166ed8b641d8ac1837d0b75329e02ed4056704/fonts/Public%20Sans/LICENSE.txt). | ||||
| * The [DM Mono](https://github.com/privacyguides/brand/tree/67166ed8b641d8ac1837d0b75329e02ed4056704/fonts/DM%20Mono) font used for monospaced text on the site is licensed under the [SIL Open Font License 1.1](https://github.com/privacyguides/brand/blob/67166ed8b641d8ac1837d0b75329e02ed4056704/fonts/DM%20Mono/LICENSE.txt). | ||||
|  | ||||
| This means that you can use the human-readable content in this repository for your own project, per the terms outlined in the Creative Commons Attribution-NoDerivatives 4.0 International Public License text. You may do so in any reasonable manner, but not in any way that suggests Privacy Guides endorses you or your use. You **may not** use the Privacy Guides branding in your own project without express approval from this project. Privacy Guides's brand trademarks include the "Privacy Guides" wordmark and shield logo. | ||||
|  | ||||
| We believe that the logos and other images in `assets` obtained from third-party providers are either in the public domain or **fair use**. In a nutshell, legal [fair use doctrine](https://copyright.gov/fair-use/more-info.html) allows the use of copyrighted images in order to identify the subject matter for purposes of public comment. However, these logos and other images may still be subject to trademark laws in one or more jurisdictions. Before using this content, please ensure that it is used to identify the entity or organization that owns the trademark and that you have the right to use it under the laws which apply in the circumstances of your intended use. *When copying content from this website, you are solely responsible for ensuring that you do not infringe someone else's trademark or copyright.* | ||||
|  | ||||
| When you contribute to our website you are doing so under the above licenses, and you are granting 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 and distribute your contribution as part of our project. | ||||
|  | ||||
| ## Acceptable Use | ||||
|  | ||||
| You may not use this website in any way that causes or may cause damage to the website or impairment of the availability or accessibility of Privacy Guides, or in any way which is unlawful, illegal, fraudulent, harmful, or in connection with any unlawful, illegal, fraudulent, or harmful purpose or activity. | ||||
|  | ||||
| You must not conduct any systematic or automated data collection activities on or in relation to this website without express written consent, including: | ||||
|  | ||||
| * Excessive Automated Scans | ||||
| * Denial of Service Attacks | ||||
| * Scraping | ||||
| * Data Mining | ||||
| * 'Framing' (IFrames) | ||||
|  | ||||
| --- | ||||
|  | ||||
| *Portions of this notice itself were adopted from [opensource.guide](https://github.com/github/opensource.guide/blob/master/notices.md) on GitHub. That resource and this page itself are released under [CC-BY-4.0](https://creativecommons.org/licenses/by-sa/4.0).* | ||||
							
								
								
									
										48
									
								
								docs/about/privacy-policy.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,48 @@ | ||||
| --- | ||||
| title: "Privacy Policy" | ||||
| --- | ||||
| Privacy Guides is a community project operated by a number of active volunteer contributors. The public list of team members [can be found on GitHub](https://github.com/orgs/privacyguides/people). | ||||
|  | ||||
| ## Data We Collect From Visitors | ||||
|  | ||||
| The privacy of our website visitors is important to us, so we do not track any individual people. As a visitor to our website: | ||||
|  | ||||
| - No personal information is stored | ||||
| - No information is shared with, sent to or sold to third-parties | ||||
| - No information is shared with advertising companies | ||||
| - No information is mined and harvested for personal and behavioral trends | ||||
| - No information is monetized | ||||
|  | ||||
| You can view the data we collect on our [statistics](statistics.md) page. | ||||
|  | ||||
| We run a self-hosted installation of [Umami](https://umami.is) to collect some anonymous usage data for statistical purposes. The goal is to track overall trends in our website traffic, it is not to track individual visitors. All the data is in aggregate only, and no personal data is stored. | ||||
|  | ||||
| The only data which is collected is data sent in a standard web request, which includes referral sources, the page you're visiting, your user agent, your IP address, and your screen resolution. The raw data is immediately discarded after statistics have been generated, for example if we collect your screen resolution as `1125x2436`, the only data we retain is "mobile device" and not your specific resolution. | ||||
|  | ||||
| ## Data We Collect From Account Holders | ||||
|  | ||||
| If you register for an account on one of our services, we may collect any information you provide us (such as your email, password, profile information, etc.) and use that information to provide you with the service. We never share or sell this data. | ||||
|  | ||||
| Some services we host have separate privacy policies which supersede this document. For example, the privacy policy of our forum can be found at [discuss.privacyguides.net/privacy](https://discuss.privacyguides.net/privacy). | ||||
|  | ||||
| ## Contacting Us | ||||
|  | ||||
| Even in the limited cases where your data is collected, our volunteers and most members of the Privacy Guides team have no access to that information. Some information (such as your email address) may be accessible to moderators via limited control panels for the purposes of moderating our communities. | ||||
|  | ||||
| Thus, inquiries regarding your personal information should be sent directly to: | ||||
|  | ||||
| ```text | ||||
| Jonah Aragon | ||||
| Services Administrator | ||||
| jonah@privacyguides.org | ||||
| ``` | ||||
|  | ||||
| For all other inquiries, you can contact any member of our team. | ||||
|  | ||||
| For complaints under GDPR more generally, you always have the option to lodge complaints with your local data protection supervisory authorities. | ||||
|  | ||||
| ## About This Policy | ||||
|  | ||||
| We will post any new versions of this statement [here](privacy-policy.md). We may change how we announce changes in future versions of this document. In the meantime we may update our contact information at any time without announcing a change. Please refer to the [Privacy Policy](privacy-policy.md) for the latest contact information at any time. | ||||
|  | ||||
| A full revision [history](https://github.com/privacyguides/privacyguides.org/commits/main/docs/about/privacy-policy.md) of this page can be found on GitHub. | ||||
							
								
								
									
										115
									
								
								docs/about/privacytools.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,115 @@ | ||||
| --- | ||||
| title: "PrivacyTools FAQ" | ||||
| --- | ||||
| In September 2021, every active contributor unanimously agreed to move from PrivacyTools to work on this site: Privacy Guides. This decision was made because PrivacyTools’ founder and controller of the domain name had disappeared for an extended period of time and could not be contacted. | ||||
|  | ||||
| Having built a reputable site and set of services on PrivacyTools.io, this caused grave concerns for the future of PrivacyTools, as any future disruption could wipe out the entire organization with no recovery method. This transition was communicated to the PrivacyTools community many months in advance via a variety of channels including its blog, Twitter, Reddit, and Mastodon to ensure the entire process went as smoothly as possible. We did this to ensure nobody was kept in the dark, which has been our modus operandi since our team was created, and to make sure Privacy Guides was recognized as the same reliable organization that PrivacyTools was before the transition. | ||||
|  | ||||
| After the organizational move was completed, the founder of PrivacyTools returned and began to spread misinformation about the Privacy Guides project. They continue to spread misinformation in addition to operating a paid link farm on the PrivacyTools domain. We are creating this page to clear up any misconceptions. | ||||
|  | ||||
| ## What is PrivacyTools? | ||||
|  | ||||
| PrivacyTools was created in 2015 by "BurungHantu," who wanted to make a privacy information resource - helpful tools following the Snowden revelations. The site grew into a flourishing open-source project with [many contributors](https://github.com/privacytools/privacytools.io/graphs/contributors), some eventually given various organizational responsibilities, such as operating online services like Matrix and Mastodon, managing and reviewing changes to the site on GitHub, finding sponsors for the project, writing blog posts and operating social media outreach platforms like Twitter, etc. | ||||
|  | ||||
| Beginning in 2019, BurungHantu grew more and more distant from the active development of the website and communities, and began delaying payments he was responsible for related to the servers we operated. To avoid having our system administrator pay server costs out of their own pocket, we changed the donation methods listed on the site from BurungHantu's personal PayPal and crypto accounts to a new OpenCollective page on [October 31, 2019](https://web.archive.org/web/20210729184557/https://blog.privacytools.io/privacytools-io-joins-the-open-collective-foundation). This had the added benefits of making our finances completely transparent, a value we strongly believe in, and tax-deductible in the United States, because they were being held by the Open Collective Foundation 501(c)3. This change was unanimously agreed upon by the team and went uncontested. | ||||
|  | ||||
| ## Why We Moved On | ||||
|  | ||||
| In 2020, BurungHantu's absence grew much more noticeable. At one point, we required the domain's nameservers to be changed to nameservers controlled by our system administrator to avoid future disruption, and this change was not completed for over a month after the initial request. He would disappear from the public chat and private team chat rooms on Matrix for months at a time, occasionally popping in to give some small feedback or promise to be more active before disappearing once again. | ||||
|  | ||||
| In October 2020, the PrivacyTools system administrator (Jonah) [left](https://web.archive.org/web/20210729190742/https://blog.privacytools.io/blacklight447-taking-over) the project because of these difficulties, handing control to another long-time contributor. Jonah had been operating nearly every PrivacyTools service and acting as the *de facto* project lead for website development in BurungHantu's absence, thus his departure was a significant change to the organization. At the time, because of these significant organizational changes, BurungHantu promised the remaining team he would return to take control of the project going forward. ==The PrivacyTools team reached out via several communication methods over the following months, but did not receive any response.== | ||||
|  | ||||
| ## Domain Name Reliance | ||||
|  | ||||
| At the beginning of 2021, the PrivacyTools team grew worried about the future of the project, because the domain name was set to expire on 1st March 2021. The domain was ultimately renewed by BurungHantu with no comment. | ||||
|  | ||||
| The team’s concerns were not addressed, and we realized this would be a problem every year: If the domain expired it would have allowed it to be stolen by squatters or spammers, thus ruining the organization's reputation. We also would have had trouble reaching the community to inform them of what took place. | ||||
|  | ||||
| Without being in any contact with BurungHantu, we decided the best course of action would be to move to a new domain name while we still had guaranteed control over the old domain name, sometime before March 2022. This way, we would be able to cleanly redirect all PrivacyTools resources to the new site without any interruption in service. This decision was made many months in advance and communicated to the entire team in the hopes that BurungHantu would reach out and assure his continued support for the project, because with a recognizable brand name and large communities online, moving away from "PrivacyTools" was the least desirable possible outcome. | ||||
|  | ||||
| In mid-2021 the PrivacyTools team reached out to Jonah, who agreed to rejoin the team to help with the transition. | ||||
|  | ||||
| ## Community Call to Action | ||||
|  | ||||
| At the end of July 2021, we [informed](https://web.archive.org/web/20210729184422/https://blog.privacytools.io/the-future-of-privacytools) the PrivacyTools community of our intention to choose a new name and continue the project on a new domain, to be [chosen](https://web.archive.org/web/20210729190935/https://aragon.cloud/apps/forms/cMPxG9KyopapBbcw) on 2nd August 2022. In the end, "Privacy Guides" was selected, with the `privacyguides.org` domain already owned by Jonah for a side-project from 2020 that went undeveloped. | ||||
|  | ||||
| ## Control of r/privacytoolsIO | ||||
|  | ||||
| Simultaneously with the ongoing website issues at privacytools.io, the r/privacytoolsIO moderation team was facing challenges with managing the subreddit. The subreddit had always been operated mostly independently of the website's development, but BurungHantu was the primary moderator of the subreddit as well, and he was the only moderator granted "Full Control" privileges. u/trai_dep was the only active moderator at the time, and [posted](https://reddit.com/comments/o9tllh) a request to Reddit's administrators on June 28, 2021, asking to be granted the primary moderator position and full control privileges, in order to make necessary changes to the Subreddit. | ||||
|  | ||||
| Reddit requires that subreddits have active moderators. If the primary moderator is inactive for a lengthy period of time (such as a year) the primary moderation position can be re-appointed to the next moderator in line. For this request to have been granted, BurungHantu had to have been completely absent from all Reddit activity for a long period of time, which was consistent with his behaviors on other platforms. | ||||
|  | ||||
| > If you were removed as moderator from a subreddit through Reddit request it is because your lack of response and lack of activity qualified the subreddit for an r/redditrequest transfer. | ||||
| > | ||||
| > r/redditrequest is Reddit's way of making sure communities have active moderators and is part of the [Moderator Code of Conduct](https://redditinc.com/policies/moderator-code-of-conduct). | ||||
|  | ||||
| ## Beginning the Transition | ||||
|  | ||||
| On September 14th, 2021, we [announced](https://blog.privacyguides.org/2021/09/14/welcome-to-privacy-guides) the beginning of our migration to this new domain: | ||||
|  | ||||
| > [...] we found it necessary to make this switch sooner rather than later to ensure people would find out about this transition as soon as possible. This gives us adequate time to transition the domain name, which is currently redirecting to `www.privacyguides.org`, and it hopefully gives everyone enough time to notice the change, update bookmarks and websites, etc. | ||||
|  | ||||
| This change [entailed:](https://reddit.com/comments/pnhn4a) | ||||
|  | ||||
| - Redirecting `www.privacytools.io` to [www.privacyguides.org](https://www.privacyguides.org). | ||||
| - Archiving the source code on GitHub to preserve our past work and issue tracker, which we continued to use for months of future development of this site. | ||||
| - Posting announcements to our subreddit and various other communities informing people of the official change. | ||||
| - Formally closing privacytools.io services, like Matrix and Mastodon, and encouraging existing users to migrate as soon as possible. | ||||
|  | ||||
| Things appeared to be going smoothly, and most of our active community made the switch to our new project exactly as we hoped. | ||||
|  | ||||
| ## Following Events | ||||
|  | ||||
| Roughly a week following the transition, BurungHantu returned online for the first time in nearly a year, however nobody on our team was willing to return to PrivacyTools because of his historic unreliability. Rather than apologize for his prolonged absence, he immediately went on the offensive and positioned the transition to Privacy Guides as an attack against him and his project. He subsequently [deleted](https://reddit.com/comments/pp9yie/comment/hd49wbn) many of these posts when it was pointed out by the community that he had been absent and abandoned the project. | ||||
|  | ||||
| At this point, BurungHantu claimed he wanted to continue working on privacytools.io on his own and requested that we remove the redirect from `www.privacytools.io` to [www.privacyguides.org](https://www.privacyguides.org). We obliged and requested that he keep the subdomains for Matrix, Mastodon, and PeerTube active for us to run as a public service to our community for at least a few months, in order to allow users on those platforms to easily migrate to other accounts. Due to the federated nature of the services we provided, they were tied to specific domain names making it very difficult to migrate (and in some cases impossible). | ||||
|  | ||||
| Unfortunately, because control of the r/privacytoolsIO subreddit was not returned to BurungHantu at his demand (further information below), those subdomains were [cut off](https://reddit.com/comments/pymthv/comment/hexwrps) at the beginning of October, ending any migration possibilities to any users still using those services. | ||||
|  | ||||
| Following this, BurungHantu made false accusations about Jonah stealing donations from the project. BurungHantu had over a year since the alleged incident occurred, and yet he never made anyone aware of it until after the Privacy Guides migration. BurungHantu has been repeatedly asked for proof and to comment on the reason for his silence by the team [and the community](https://twitter.com/TommyTran732/status/1526153536962281474), and has not done so. | ||||
|  | ||||
| BurungHantu also made a [twitter post](https://twitter.com/privacytoolsIO/status/1510560676967710728) alleging that an "attorney" had reached out to him on Twitter and was providing advice, in another attempt to bully us into giving him control of our subreddit, and as part of his smear campaign to muddy the waters surrounding the launch of Privacy Guides while pretending to be a victim. | ||||
|  | ||||
| ## PrivacyTools.io Now | ||||
|  | ||||
| As of September 25th 2022 we are seeing BurungHantu's overall plans come to fruition on privacytools.io, and this is the very reason we decided to create this explainer page today. The website he is operating appears to be a heavily SEO-optimized version of the site which recommends tools in exchange for financial compensation. Very recently, IVPN and Mullvad, two VPN providers near-universally [recommended](../vpn.md) by the privacy community and notable for their stance against affiliate programs were removed from PrivacyTools. In their place? NordVPN, Surfshark, ExpressVPN, and hide.me; Giant VPN corporations with untrustworthy platforms and business practices, notorious for their aggressive marketing and affiliate programs. | ||||
|  | ||||
| ==**PrivacyTools has become exactly the type of site we [warned against](https://web.archive.org/web/20210729205249/https://blog.privacytools.io/the-trouble-with-vpn-and-privacy-reviews) on the PrivacyTools blog in 2019.**== We've tried to keep our distance from PrivacyTools since the transition, but their continued harassment towards our project and now their absurd abuse of the credibility their brand gained over 6 years of open-source contributions is extremely troubling to us. Those of us actually fighting for privacy are not fighting against each other, and are not getting our advice from the highest bidder. | ||||
|  | ||||
| ## r/privacytoolsIO Now | ||||
|  | ||||
| After the launch of [r/PrivacyGuides](https://reddit.com/r/privacyguides), it was impractical for u/trai_dep to continue moderating both subreddits, and with the community on-board with the transition, r/privacytoolsIO was [made](https://reddit.com/comments/qk7qrj) a restricted sub in a post on November 1st, 2021: | ||||
|  | ||||
| > [...] The growth of this Sub was the result of great effort, across several years, by the PrivacyGuides.org team. And by every one of you. | ||||
| > | ||||
| > A Subreddit is a great deal of work to administer and moderate. Like a garden, it requires patient tending and daily care. It's not a task for dilettantes or commitment-challenged people. It can’t thrive under a gardener who abandons it for several years, then shows up demanding this year’s harvest as their tribute. It's unfair to the team formed years ago. It’s unfair to you. [...] | ||||
|  | ||||
| Subreddits do not belong to anybody, and they especially do not belong to brand-holders. They belong to their communities, and the community and its moderators made the decision to support the move to r/PrivacyGuides. | ||||
|  | ||||
| In the months since, BurungHantu has threatened and begged for returning subreddit control to his account in [violation](https://reddit.com/r/redditrequest/wiki/top_mod_removal) of Reddit rules: | ||||
|  | ||||
| > Retaliation from any moderator with regards to removal requests is disallowed. | ||||
|  | ||||
| For a community with many thousands of remaining subscribers, we feel that it would be incredibly disrespectful to return control of that massive platform to the person who abandoned it for over a year, and who now operates a website that we feel provides very low-quality information. Preserving the years of past discussions in that community is more important to us, and thus u/trai_dep and the rest of the subreddit moderation team has made the decision to keep r/privacytoolsIO as-is. | ||||
|  | ||||
| ## OpenCollective Now | ||||
|  | ||||
| Our fundraising platform, OpenCollective, is another source of contention. Our position is that OpenCollective was put in place by our team and managed by our team to fund services we currently operate and which PrivacyTools no longer does. We [reached out](https://opencollective.com/privacyguides/updates/transitioning-to-privacy-guides) to all of our donors regarding our move to Privacy Guides, and we were unanimously supported by our sponsors and community. | ||||
|  | ||||
| Thus, the funds in OpenCollective belong to Privacy Guides, they were given to our project, and not the owner of a well known domain name. In the announcement made to donors on September 17th, 2021, we offered refunds to any donor who disagrees with the stance we took, but nobody has taken us up on this offer: | ||||
|  | ||||
| > If any sponsors or backers disagree with or feel misled by these recent events and would like to request a refund given these highly unusual circumstances, please get in touch with our project admin by emailing `jonah@triplebit.net`. | ||||
|  | ||||
| ## Further Reading | ||||
|  | ||||
| This topic has been discussed extensively within our communities in various locations, and it seems likely that most people reading this page will already be familiar with the events leading up to the move to Privacy Guides. Some of our previous posts on the matter may have extra detail we omitted here for brevity. They have been linked below for the sake of completion. | ||||
|  | ||||
| - [June 28, 2021 request for control of r/privacytoolsIO](https://reddit.com/comments/o9tllh) | ||||
| - [July 27, 2021 announcement of our intentions to move on the PrivacyTools blog, written by the team](https://web.archive.org/web/20210729184422/https://blog.privacytools.io/the-future-of-privacytools) | ||||
| - [Sept 13, 2021 announcement of the beginning of our transition to Privacy Guides on r/privacytoolsIO](https://reddit.com/pnql46) | ||||
| - [Sept 17, 2021 announcement on OpenCollective from Jonah](https://opencollective.com/privacyguides/updates/transitioning-to-privacy-guides) | ||||
| - [Sept 30, 2021 Twitter thread detailing most of the events now described on this page](https://twitter.com/privacy_guides/status/1443633412800225280) | ||||
| - [Oct 1, 2021 post by u/dng99 noting subdomain failure](https://reddit.com/comments/pymthv/comment/hexwrps) | ||||
| - [Apr 2, 2022 response by u/dng99 to PrivacyTools' accusatory blog post](https://reddit.com/comments/tuo7mm/comment/i35kw5a) | ||||
| - [May 16, 2022 response by @TommyTran732 on Twitter](https://twitter.com/TommyTran732/status/1526153497984618496) | ||||
| - [Sep 3, 2022 post on Techlore's forum by @dngray](https://discuss.techlore.tech/t/has-anyone-seen-this-video-wondering-your-thoughts/792/20) | ||||
							
								
								
									
										38
									
								
								docs/about/services.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,38 @@ | ||||
| # Privacy Guides Services | ||||
|  | ||||
| We run a number of web services to test out features and promote cool decentralized, federated, and/or open-source projects. Many of these services are available to the public and are detailed below. | ||||
|  | ||||
| [:material-comment-alert: Report an issue](https://discuss.privacyguides.net/c/services/2){ class="md-button md-button--primary" } | ||||
|  | ||||
| ## Discourse | ||||
|  | ||||
| - Domain: [discuss.privacyguides.net](https://discuss.privacyguides.net) | ||||
| - Availability: Public | ||||
| - Source: [github.com/discourse/discourse](https://github.com/discourse/discourse) | ||||
|  | ||||
| ## Gitea | ||||
|  | ||||
| - Domain: [code.privacyguides.dev](https://code.privacyguides.dev) | ||||
| - Availability: Invite-Only | ||||
| Access may be granted upon request to any team working on *Privacy Guides*-related development or content. | ||||
| - Source: [snapcraft.io/gitea](https://snapcraft.io/gitea) | ||||
|  | ||||
| ## Matrix | ||||
|  | ||||
| - Domain: [matrix.privacyguides.org](https://matrix.privacyguides.org) | ||||
| - Availability: Invite-Only | ||||
| Access may be granted upon request to Privacy Guides team members, Matrix moderators, third-party Matrix community administrators, Matrix bot operators, and other individuals in need of a reliable Matrix presence. | ||||
| - Source: [github.com/spantaleev/matrix-docker-ansible-deploy](https://github.com/spantaleev/matrix-docker-ansible-deploy) | ||||
|  | ||||
| ## SearXNG | ||||
|  | ||||
| - Domain: [search.privacyguides.net](https://search.privacyguides.net) | ||||
| - Availability: Public | ||||
| - Source: [github.com/searxng/searxng-docker](https://github.com/searxng/searxng-docker) | ||||
|  | ||||
| ## Invidious | ||||
|  | ||||
| - Domain: [invidious.privacyguides.net](https://invidious.privacyguides.net) | ||||
| - Availability: Semi-Public | ||||
| We host Invidious primarily to serve embedded YouTube videos on our website, this instance is not intended for general-purpose use and may be limited at any time. | ||||
| - Source: [github.com/iv-org/invidious](https://github.com/iv-org/invidious) | ||||
							
								
								
									
										14
									
								
								docs/about/statistics.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,14 @@ | ||||
| --- | ||||
| title: Traffic Statistics | ||||
| --- | ||||
|  | ||||
| We self-host [Umami](https://umami.is) to create a nice visualization of our traffic statistics, which are public at the link below. With this process: | ||||
|  | ||||
| - Your information is never shared with a third-party, it stays on servers we control | ||||
| - Your personal data is never saved, we only collect data in aggregate | ||||
| - No client-side JavaScript is required | ||||
|  | ||||
| Because of these facts, keep in mind our statistics may be inaccurate. It is a useful tool to compare different dates with each other and analyze overall trends, but the actual numbers may be far off from reality. They're *precise* statistics, but not *accurate* statistics. | ||||
|  | ||||
| [View Statistics](https://stats.privacyguides.net/share/nVWjyd2QfgOPBhMF/www.privacyguides.org){ .md-button .md-button--primary } | ||||
| [Opt-Out](#__consent){ .md-button } | ||||
							
								
								
									
										103
									
								
								docs/advanced/communication-network-types.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,103 @@ | ||||
| --- | ||||
| title: "Types of Communication Networks" | ||||
| icon: 'material/transit-connection-variant' | ||||
| description: An overview of several network architectures commonly used by instant messaging applications. | ||||
| --- | ||||
|  | ||||
| There are several network architectures commonly used to relay messages between people. These networks can provide different privacy guarantees, which is why it's worth considering your [threat model](../basics/threat-modeling.md) when deciding which app to use. | ||||
|  | ||||
| [Recommended Instant Messengers](../real-time-communication.md){ .md-button } | ||||
|  | ||||
| ## Centralized Networks | ||||
|  | ||||
| { align=left } | ||||
|  | ||||
| Centralized messengers are those where all participants are on the same server or network of servers controlled by the same organization. | ||||
|  | ||||
| Some self-hosted messengers allow you to set up your own server. Self-hosting can provide additional privacy guarantees, such as no usage logs or limited access to metadata (data about who is talking to whom). Self-hosted centralized messengers are isolated and everyone must be on the same server to communicate. | ||||
|  | ||||
| **Advantages:** | ||||
|  | ||||
| - New features and changes can be implemented more quickly. | ||||
| - Easier to get started with and to find contacts. | ||||
| - Most mature and stable features ecosystems, as they are easier to program in a centralized software. | ||||
| - Privacy issues may be reduced when you trust a server that you're self-hosting. | ||||
|  | ||||
| **Disadvantages:** | ||||
|  | ||||
| - Can include [restricted control or access](https://drewdevault.com/2018/08/08/Signal.html). This can include things like: | ||||
| - Being [forbidden from connecting third-party clients](https://github.com/LibreSignal/LibreSignal/issues/37#issuecomment-217211165) to the centralized network that might provide for greater customization or a better experience. Often defined in Terms and Conditions of usage. | ||||
| - Poor or no documentation for third-party developers. | ||||
| - The [ownership](https://web.archive.org/web/20210729191953/https://blog.privacytools.io/delisting-wire), privacy policy, and operations of the service can change easily when a single entity controls it, potentially compromising the service later on. | ||||
| - Self-hosting requires effort and knowledge of how to set up a service. | ||||
|  | ||||
| ## Federated Networks | ||||
|  | ||||
| { align=left } | ||||
|  | ||||
| Federated messengers use multiple, independent, decentralized servers that are able to talk to each other (email is one example of a federated service). Federation allows system administrators to control their own server and still be a part of the larger communications network. | ||||
|  | ||||
| When self-hosted, members of a federated server can discover and communicate with members of other servers, although some servers may choose to remain private by being non-federated (e.g., work team server). | ||||
|  | ||||
| **Advantages:** | ||||
|  | ||||
| - Allows for greater control over your own data when running your own server. | ||||
| - Allows you to choose whom to trust your data with by choosing between multiple "public" servers. | ||||
| - Often allows for third-party clients which can provide a more native, customized, or accessible experience. | ||||
| - Server software can be verified that it matches public source code, assuming you have access to the server or you trust the person who does (e.g., a family member). | ||||
|  | ||||
| **Disadvantages:** | ||||
|  | ||||
| - Adding new features is more complex because these features need to be standardized and tested to ensure they work with all servers on the network. | ||||
| - Due to the previous point, features can be lacking, or incomplete or working in unexpected ways compared to centralized platforms, such as message relay when offline or message deletion. | ||||
| - Some metadata may be available (e.g., information like "who is talking to whom," but not actual message content if E2EE is used). | ||||
| - Federated servers generally require trusting your server's administrator. They may be a hobbyist or otherwise not a "security professional," and may not serve standard documents like a privacy policy or terms of service detailing how your data is used. | ||||
| - Server administrators sometimes choose to block other servers, which are a source of unmoderated abuse or break general rules of accepted behavior. This will hinder your ability to communicate with members of those servers. | ||||
|  | ||||
| ## Peer-to-Peer Networks | ||||
|  | ||||
| { align=left } | ||||
|  | ||||
| P2P messengers connect to a [distributed network](https://en.wikipedia.org/wiki/Distributed_networking) of nodes to relay a message to the recipient without a third-party server. | ||||
|  | ||||
| Clients (peers) usually find each other through the use of a [distributed computing](https://en.wikipedia.org/wiki/Distributed_computing) network. Examples of this include [Distributed Hash Tables](https://en.wikipedia.org/wiki/Distributed_hash_table) (DHT), used by [torrents](https://en.wikipedia.org/wiki/BitTorrent_(protocol)) and [IPFS](https://en.wikipedia.org/wiki/InterPlanetary_File_System) for example. Another approach is proximity based networks, where a connection is established over WiFi or Bluetooth (for example, Briar or the [Scuttlebutt](https://scuttlebutt.nz) social network protocol). | ||||
|  | ||||
| Once a peer has found a route to its contact via any of these methods, a direct connection between them is made. Although messages are usually encrypted, an observer can still deduce the location and identity of the sender and recipient. | ||||
|  | ||||
| P2P networks do not use servers, as peers communicate directly between each other and hence cannot be self-hosted. However, some additional services may rely on centralized servers, such as user discovery or relaying offline messages, which can benefit from self-hosting. | ||||
|  | ||||
| **Advantages:** | ||||
|  | ||||
| - Minimal information is exposed to third-parties. | ||||
| - Modern P2P platforms implement E2EE by default. There are no servers that could potentially intercept and decrypt your transmissions, unlike centralized and federated models. | ||||
|  | ||||
| **Disadvantages:** | ||||
|  | ||||
| - Reduced feature set: | ||||
| - Messages can only be sent when both peers are online, however, your client may store messages locally to wait for the contact to return online. | ||||
| - Generally increases battery usage on mobile devices, because the client must stay connected to the distributed network to learn about who is online. | ||||
| - Some common messenger features may not be implemented or incompletely, such as message deletion. | ||||
| - Your IP address and that of the contacts you're communicating with may be exposed if you do not use the software in conjunction with a [VPN](../vpn.md) or [Tor](../tor.md). Many countries have some form of mass surveillance and/or metadata retention. | ||||
|  | ||||
| ## Anonymous Routing | ||||
|  | ||||
| { align=left } | ||||
|  | ||||
| A messenger using [anonymous routing](https://doi.org/10.1007/978-1-4419-5906-5_628) hides either the identity of the sender, the receiver, or evidence that they have been communicating. Ideally, a messenger should hide all three. | ||||
|  | ||||
| There are [many](https://doi.org/10.1145/3182658) different ways to implement anonymous routing. One of the most famous is [onion routing](https://en.wikipedia.org/wiki/Onion_routing) (i.e. [Tor](tor-overview.md)), which communicates encrypted messages through a virtual [overlay network](https://en.wikipedia.org/wiki/Overlay_network) that hides the location of each node as well as the recipient and sender of each message. The sender and recipient never interact directly and only meet through a secret rendezvous node so that there is no leak of IP addresses nor physical location. Nodes cannot decrypt messages, nor the final destination; only the recipient can. Each intermediary node can only decrypt a part that indicates where to send the still encrypted message next, until it arrives at the recipient who can fully decrypt it, hence the "onion layers." | ||||
|  | ||||
| Self-hosting a node in an anonymous routing network does not provide the hoster with additional privacy benefits, but rather contributes to the whole network's resilience against identification attacks for everyone's benefit. | ||||
|  | ||||
| **Advantages:** | ||||
|  | ||||
| - Minimal to no information is exposed to other parties. | ||||
| - Messages can be relayed in a decentralized manner even if one of the parties is offline. | ||||
|  | ||||
| **Disadvantages:** | ||||
|  | ||||
| - Slow message propagation. | ||||
| - Often limited to fewer media types, mostly text, since the network is slow. | ||||
| - Less reliable if nodes are selected by randomized routing, some nodes may be very far from the sender and receiver, adding latency or even failing to transmit messages if one of the nodes goes offline. | ||||
| - More complex to get started, as the creation and secured backup of a cryptographic private key is required. | ||||
| - Just like other decentralized platforms, adding features is more complex for developers than on a centralized platform. Hence, features may be lacking or incompletely implemented, such as offline message relaying or message deletion. | ||||
							
								
								
									
										363
									
								
								docs/advanced/dns-overview.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,363 @@ | ||||
| --- | ||||
| title: "DNS Overview" | ||||
| icon: material/dns | ||||
| description: The Domain Name System is the "phonebook of the internet," helping your browser find the website it's looking for. | ||||
| --- | ||||
|  | ||||
| The [Domain Name System](https://en.wikipedia.org/wiki/Domain_Name_System) is the 'phonebook of the Internet'. DNS translates domain names to IP addresses so browsers and other services can load Internet resources, through a decentralized network of servers. | ||||
|  | ||||
| ## What is DNS? | ||||
|  | ||||
| When you visit a website, a numerical address is returned. For example, when you visit `privacyguides.org`, the address `192.98.54.105` is returned. | ||||
|  | ||||
| DNS has existed since the [early days](https://en.wikipedia.org/wiki/Domain_Name_System#History) of the Internet. DNS requests made to and from DNS servers are **not** generally encrypted. In a residential setting, a customer is given servers by the ISP via [DHCP](https://en.wikipedia.org/wiki/Dynamic_Host_Configuration_Protocol). | ||||
|  | ||||
| Unencrypted DNS requests are able to be easily **surveilled** and **modified** in transit. In some parts of the world, ISPs are ordered to do primitive [DNS filtering](https://en.wikipedia.org/wiki/DNS_blocking). When you request the IP address of a domain that is blocked, the server may not respond or may respond with a different IP address. As the DNS protocol is not encrypted, the ISP (or any network operator) can use [DPI](https://en.wikipedia.org/wiki/Deep_packet_inspection) to monitor requests. ISPs can also block requests based on common characteristics, regardless of which DNS server is used. Unencrypted DNS always uses [port](https://en.wikipedia.org/wiki/Port_(computer_networking)) 53 and always uses UDP. | ||||
|  | ||||
| Below, we discuss and provide a tutorial to prove what an outside observer may see using regular unencrypted DNS and [encrypted DNS](#what-is-encrypted-dns). | ||||
|  | ||||
| ### Unencrypted DNS | ||||
|  | ||||
| 1. Using [`tshark`](https://wireshark.org/docs/man-pages/tshark.html) (part of the [Wireshark](https://en.wikipedia.org/wiki/Wireshark) project) we can monitor and record internet packet flow. This command records packets that meet the rules specified: | ||||
|  | ||||
|     ```bash | ||||
|     tshark -w /tmp/dns.pcap udp port 53 and host 1.1.1.1 or host 8.8.8.8 | ||||
|     ``` | ||||
|  | ||||
| 2. We can then use [`dig`](https://en.wikipedia.org/wiki/Dig_(command)) (Linux, MacOS, etc.) or [`nslookup`](https://en.wikipedia.org/wiki/Nslookup) (Windows) to send the DNS lookup to both servers. Software such as web browsers do these lookups automatically, unless they are configured to use encrypted DNS. | ||||
|  | ||||
|     === "Linux, macOS" | ||||
|  | ||||
|         ``` | ||||
|         dig +noall +answer privacyguides.org @1.1.1.1 | ||||
|         dig +noall +answer privacyguides.org @8.8.8.8 | ||||
|         ``` | ||||
|     === "Windows" | ||||
|  | ||||
|         ``` | ||||
|         nslookup privacyguides.org 1.1.1.1 | ||||
|         nslookup privacyguides.org 8.8.8.8 | ||||
|         ``` | ||||
|  | ||||
| 3. Next, we want to [analyse](https://wireshark.org/docs/wsug_html_chunked/ChapterIntroduction.html#ChIntroWhatIs) the results: | ||||
|  | ||||
|     === "Wireshark" | ||||
|  | ||||
|         ``` | ||||
|         wireshark -r /tmp/dns.pcap | ||||
|         ``` | ||||
|  | ||||
|     === "tshark" | ||||
|  | ||||
|         ``` | ||||
|         tshark -r /tmp/dns.pcap | ||||
|         ``` | ||||
|  | ||||
| If you run the Wireshark command above, the top pane shows the "[frames](https://en.wikipedia.org/wiki/Ethernet_frame)", and the bottom pane shows all the data about the selected frame. Enterprise filtering and monitoring solutions (such as those purchased by governments) can do the process automatically, without human interaction, and can aggregate those frames to produce statistical data useful to the network observer. | ||||
|  | ||||
| | No. | Time     | Source    | Destination | Protocol | Length | Info                                                                   | | ||||
| |-----|----------|-----------|-------------|----------|--------|------------------------------------------------------------------------| | ||||
| | 1   | 0.000000 | 192.0.2.1 | 1.1.1.1     | DNS      | 104    | Standard query 0x58ba A privacyguides.org OPT                          | | ||||
| | 2   | 0.293395 | 1.1.1.1   | 192.0.2.1   | DNS      | 108    | Standard query response 0x58ba A privacyguides.org A 198.98.54.105 OPT | | ||||
| | 3   | 1.682109 | 192.0.2.1 | 8.8.8.8     | DNS      | 104    | Standard query 0xf1a9 A privacyguides.org OPT                          | | ||||
| | 4   | 2.154698 | 8.8.8.8   | 192.0.2.1   | DNS      | 108    | Standard query response 0xf1a9 A privacyguides.org A 198.98.54.105 OPT | | ||||
|  | ||||
| An observer could modify any of these packets. | ||||
|  | ||||
| ## What is "encrypted DNS"? | ||||
|  | ||||
| Encrypted DNS can refer to one of a number of protocols, the most common ones being: | ||||
|  | ||||
| ### DNSCrypt | ||||
|  | ||||
| [**DNSCrypt**](https://en.wikipedia.org/wiki/DNSCrypt) was one of the first methods of encrypting DNS queries. DNSCrypt operates on port 443 and works with both the TCP or UDP transport protocols. DNSCrypt has never been submitted to the [Internet Engineering Task Force (IETF)](https://en.wikipedia.org/wiki/Internet_Engineering_Task_Force) nor has it gone through the [Request for Comments (RFC)](https://en.wikipedia.org/wiki/Request_for_Comments) process, so it has not been used widely outside of a few [implementations](https://dnscrypt.info/implementations). As a result, it has been largely replaced by the more popular [DNS over HTTPS](#dns-over-https-doh). | ||||
|  | ||||
| ### DNS over TLS (DoT) | ||||
|  | ||||
| [**DNS over TLS**](https://en.wikipedia.org/wiki/DNS_over_TLS) is another method for encrypting DNS communication that is defined in [RFC 7858](https://datatracker.ietf.org/doc/html/rfc7858). Support was first implemented in Android 9, iOS 14, and on Linux in [systemd-resolved](https://freedesktop.org/software/systemd/man/resolved.conf.html#DNSOverTLS=) in version 237. Preference in the industry has been moving away from DoT to DoH in recent years, as DoT is a [complex protocol](https://dnscrypt.info/faq) and has varying compliance to the RFC across the implementations that exist. DoT also operates on a dedicated port 853 which can be blocked easily by restrictive firewalls. | ||||
|  | ||||
| ### DNS over HTTPS (DoH) | ||||
|  | ||||
| [**DNS over HTTPS**](https://en.wikipedia.org/wiki/DNS_over_HTTPS) as defined in [RFC 8484](https://datatracker.ietf.org/doc/html/rfc8484) packages queries in the [HTTP/2](https://en.wikipedia.org/wiki/HTTP/2) protocol and provides security with HTTPS. Support was first added in web browsers such as Firefox 60 and Chrome 83. | ||||
|  | ||||
| Native implementation of DoH showed up in iOS 14, macOS 11, Microsoft Windows, and Android 13 (however, it won't be enabled [by default](https://android-review.googlesource.com/c/platform/packages/modules/DnsResolver/+/1833144)). General Linux desktop support is waiting on the systemd [implementation](https://github.com/systemd/systemd/issues/8639) so [installing third-party software is still required](../dns.md#encrypted-dns-proxies). | ||||
|  | ||||
| ### Native Operating System Support | ||||
|  | ||||
| #### Android | ||||
|  | ||||
| Android 9 and above support DNS over TLS. The settings can be found in: **Settings** → **Network & Internet** → **Private DNS**. | ||||
|  | ||||
| #### Apple Devices | ||||
|  | ||||
| The latest versions of iOS, iPadOS, tvOS, and macOS, support both DoT and DoH. Both protocols are supported natively via [configuration profiles](https://support.apple.com/guide/security/configuration-profile-enforcement-secf6fb9f053/web) or through the [DNS Settings API](https://developer.apple.com/documentation/networkextension/dns_settings). | ||||
|  | ||||
| After installation of either a configuration profile or an app that uses the DNS Settings API, the DNS configuration can be selected. If a VPN is active, resolution within the VPN tunnel will use the VPN's DNS settings and not your system-wide settings. | ||||
|  | ||||
| Apple does not provide a native interface for creating encrypted DNS profiles. [Secure DNS profile creator](https://dns.notjakob.com/tool.html) is an unofficial tool for creating your own encrypted DNS profiles, however they will not be signed. Signed profiles are preferred; signing validates a profile's origin and helps to ensure the integrity of the profiles. A green "Verified" label is given to signed configuration profiles. For more information on code signing, see [About Code Signing](https://developer.apple.com/library/archive/documentation/Security/Conceptual/CodeSigningGuide/Introduction/Introduction.html). | ||||
|  | ||||
| #### Linux | ||||
|  | ||||
| `systemd-resolved`, which many Linux distributions use to do their DNS lookups, doesn't yet [support DoH](https://github.com/systemd/systemd/issues/8639). If you want to use DoH, you'll need to install a proxy like [dnscrypt-proxy](https://github.com/DNSCrypt/dnscrypt-proxy) and [configure it](https://wiki.archlinux.org/title/Dnscrypt-proxy) to take all the DNS queries from your system resolver and forward them over HTTPS. | ||||
|  | ||||
| ## What can an outside party see? | ||||
|  | ||||
| In this example we will record what happens when we make a DoH request: | ||||
|  | ||||
| 1. First, start `tshark`: | ||||
|  | ||||
|     ```bash | ||||
|     tshark -w /tmp/dns_doh.pcap -f "tcp port https and host 1.1.1.1" | ||||
|     ``` | ||||
|  | ||||
| 2. Second, make a request with `curl`: | ||||
|  | ||||
|     ```bash | ||||
|     curl -vI --doh-url https://1.1.1.1/dns-query https://privacyguides.org | ||||
|     ``` | ||||
|  | ||||
| 3. After making the request, we can stop the packet capture with <kbd>CTRL</kbd> + <kbd>C</kbd>. | ||||
|  | ||||
| 4. Analyse the results in Wireshark: | ||||
|  | ||||
|     ```bash | ||||
|     wireshark -r /tmp/dns_doh.pcap | ||||
|     ``` | ||||
|  | ||||
| We can see the [connection establishment](https://en.wikipedia.org/wiki/Transmission_Control_Protocol#Connection_establishment) and [TLS handshake](https://cloudflare.com/learning/ssl/what-happens-in-a-tls-handshake) that occurs with any encrypted connection. When looking at the "application data" packets that follow, none of them contain the domain we requested or the IP address returned. | ||||
|  | ||||
| ## Why **shouldn't** I use encrypted DNS? | ||||
|  | ||||
| In locations where there is internet filtering (or censorship), visiting forbidden resources may have its own consequences which you should consider in your [threat model](../basics/threat-modeling.md). We do **not** suggest the use of encrypted DNS for this purpose. Use [Tor](https://torproject.org) or a [VPN](../vpn.md) instead. If you're using a VPN, you should use your VPN's DNS servers. When using a VPN, you are already trusting them with all your network activity. | ||||
|  | ||||
| When we do a DNS lookup, it's generally because we want to access a resource. Below, we will discuss some of the methods that may disclose your browsing activities even when using encrypted DNS: | ||||
|  | ||||
| ### IP Address | ||||
|  | ||||
| The simplest way to determine browsing activity might be to look at the IP addresses your devices are accessing. For example, if the observer knows that `privacyguides.org` is at `198.98.54.105`, and your device is requesting data from `198.98.54.105`, there is a good chance you're visiting Privacy Guides. | ||||
|  | ||||
| This method is only useful when the IP address belongs to a server that only hosts few websites. It's also not very useful if the site is hosted on a shared platform (e.g. Github Pages, Cloudflare Pages, Netlify, WordPress, Blogger, etc.). It also isn't very useful if the server is hosted behind a [reverse proxy](https://en.wikipedia.org/wiki/Reverse_proxy), which is very common on the modern Internet. | ||||
|  | ||||
| ### Server Name Indication (SNI) | ||||
|  | ||||
| Server Name Indication is typically used when a IP address hosts many websites. This could be a service like Cloudflare, or some other [Denial-of-service attack](https://en.wikipedia.org/wiki/Denial-of-service_attack) protection. | ||||
|  | ||||
| 1. Start capturing again with `tshark`. We've added a filter with our IP address so you don't capture many packets: | ||||
|  | ||||
|     ```bash | ||||
|     tshark -w /tmp/pg.pcap port 443 and host 198.98.54.105 | ||||
|     ``` | ||||
|  | ||||
| 2. Then we visit [https://privacyguides.org](https://privacyguides.org). | ||||
|  | ||||
| 3. After visiting the website, we want to stop the packet capture with <kbd>CTRL</kbd> + <kbd>C</kbd>. | ||||
|  | ||||
| 4. Next we want to analyze the results: | ||||
|  | ||||
|     ```bash | ||||
|     wireshark -r /tmp/pg.pcap | ||||
|     ``` | ||||
|  | ||||
|     We will see the connection establishment, followed by the TLS handshake for the Privacy Guides website. Around frame 5. you'll see a "Client Hello". | ||||
|  | ||||
| 5. Expand the triangle ▸ next to each field: | ||||
|  | ||||
|     ```text | ||||
|     ▸ Transport Layer Security | ||||
|       ▸ TLSv1.3 Record Layer: Handshake Protocol: Client Hello | ||||
|         ▸ Handshake Protocol: Client Hello | ||||
|           ▸ Extension: server_name (len=22) | ||||
|             ▸ Server Name Indication extension | ||||
|     ``` | ||||
|  | ||||
| 6. We can see the SNI value which discloses the website we are visiting. The `tshark` command can give you the value directly for all packets containing a SNI value: | ||||
|  | ||||
|     ```bash | ||||
|     tshark -r /tmp/pg.pcap -Tfields -Y tls.handshake.extensions_server_name -e tls.handshake.extensions_server_name | ||||
|     ``` | ||||
|  | ||||
| This means even if we are using "Encrypted DNS" servers, the domain will likely be disclosed through SNI. The [TLS v1.3](https://en.wikipedia.org/wiki/Transport_Layer_Security#TLS_1.3) protocol brings with it [Encrypted Client Hello](https://blog.cloudflare.com/encrypted-client-hello), which prevents this kind of leak. | ||||
|  | ||||
| Governments, in particular [China](https://zdnet.com/article/china-is-now-blocking-all-encrypted-https-traffic-using-tls-1-3-and-esni) and [Russia](https://zdnet.com/article/russia-wants-to-ban-the-use-of-secure-protocols-such-as-tls-1-3-doh-dot-esni), have either already [started blocking](https://en.wikipedia.org/wiki/Server_Name_Indication#Encrypted_Client_Hello) it or expressed a desire to do so. Recently, Russia has [started blocking foreign websites](https://github.com/net4people/bbs/issues/108) that use the [HTTP/3](https://en.wikipedia.org/wiki/HTTP/3) standard. This is because the [QUIC](https://en.wikipedia.org/wiki/QUIC) protocol that is a part of HTTP/3 requires that `ClientHello` also be encrypted. | ||||
|  | ||||
| ### Online Certificate Status Protocol (OCSP) | ||||
|  | ||||
| Another way your browser can disclose your browsing activities is with the [Online Certificate Status Protocol](https://en.wikipedia.org/wiki/Online_Certificate_Status_Protocol). When visiting an HTTPS website, the browser might check to see if the website's [certificate](https://en.wikipedia.org/wiki/Public_key_certificate) has been revoked. This is generally done through the HTTP protocol, meaning it is **not** encrypted. | ||||
|  | ||||
| The OCSP request contains the certificate "[serial number](https://en.wikipedia.org/wiki/Public_key_certificate#Common_fields)", which is unique. It is sent to the "OCSP responder" in order to check its status. | ||||
|  | ||||
| We can simulate what a browser would do using the [`openssl`](https://en.wikipedia.org/wiki/OpenSSL) command. | ||||
|  | ||||
| 1. Get the server certificate and use [`sed`](https://en.wikipedia.org/wiki/Sed) to keep just the important part and write it out to a file: | ||||
|  | ||||
|     ```bash | ||||
|     openssl s_client -connect privacyguides.org:443 < /dev/null 2>&1 | | ||||
|         sed -n '/^-*BEGIN/,/^-*END/p' > /tmp/pg_server.cert | ||||
|     ``` | ||||
|  | ||||
| 2. Get the intermediate certificate. [Certificate Authorities (CA)](https://en.wikipedia.org/wiki/Certificate_authority) normally don't sign a certificate directly; they use what is known as an "intermediate" certificate. | ||||
|  | ||||
|     ```bash | ||||
|     openssl s_client -showcerts -connect privacyguides.org:443 < /dev/null 2>&1 | | ||||
|         sed -n '/^-*BEGIN/,/^-*END/p' > /tmp/pg_and_intermediate.cert | ||||
|     ``` | ||||
|  | ||||
| 3. The first certificate in `pg_and_intermediate.cert` is actually the server certificate from step 1. We can use `sed` again to delete until the first instance of END: | ||||
|  | ||||
|     ```bash | ||||
|     sed -n '/^-*END CERTIFICATE-*$/!d;:a n;p;ba' \ | ||||
|         /tmp/pg_and_intermediate.cert > /tmp/intermediate_chain.cert | ||||
|     ``` | ||||
|  | ||||
| 4. Get the OCSP responder for the server certificate: | ||||
|  | ||||
|     ```bash | ||||
|     openssl x509 -noout -ocsp_uri -in /tmp/pg_server.cert | ||||
|     ``` | ||||
|  | ||||
|     Our certificate shows the Lets Encrypt certificate responder. | ||||
|     If we want to see all the details of the certificate we can use: | ||||
|  | ||||
|     ```bash | ||||
|     openssl x509 -text -noout -in /tmp/pg_server.cert | ||||
|     ``` | ||||
|  | ||||
| 5. Start the packet capture: | ||||
|  | ||||
|     ```bash | ||||
|     tshark -w /tmp/pg_ocsp.pcap -f "tcp port http" | ||||
|     ``` | ||||
|  | ||||
| 6. Make the OCSP request: | ||||
|  | ||||
|     ```bash | ||||
|     openssl ocsp -issuer /tmp/intermediate_chain.cert \ | ||||
|                  -cert /tmp/pg_server.cert \ | ||||
|                  -text \ | ||||
|                  -url http://r3.o.lencr.org | ||||
|     ``` | ||||
|  | ||||
| 7. Open the capture: | ||||
|  | ||||
|     ```bash | ||||
|     wireshark -r /tmp/pg_ocsp.pcap | ||||
|     ``` | ||||
|  | ||||
|     There will be two packets with the "OCSP" protocol: a "Request" and a "Response". For the "Request" we can see the "serial number" by expanding the triangle ▸ next to each field: | ||||
|  | ||||
|     ```bash | ||||
|     ▸ Online Certificate Status Protocol | ||||
|       ▸ tbsRequest | ||||
|         ▸ requestList: 1 item | ||||
|           ▸ Request | ||||
|             ▸ reqCert | ||||
|               serialNumber | ||||
|     ``` | ||||
|  | ||||
|     For the "Response" we can also see the "serial number": | ||||
|  | ||||
|     ```bash | ||||
|     ▸ Online Certificate Status Protocol | ||||
|       ▸ responseBytes | ||||
|         ▸ BasicOCSPResponse | ||||
|           ▸ tbsResponseData | ||||
|             ▸ responses: 1 item | ||||
|               ▸ SingleResponse | ||||
|                 ▸ certID | ||||
|                   serialNumber | ||||
|     ``` | ||||
|  | ||||
| 8. Or use `tshark` to filter the packets for the Serial Number: | ||||
|  | ||||
|     ```bash | ||||
|     tshark -r /tmp/pg_ocsp.pcap -Tfields -Y ocsp.serialNumber -e ocsp.serialNumber | ||||
|     ``` | ||||
|  | ||||
| If the network observer has the public certificate, which is publicly available, they can match the serial number with that certificate and therefore determine the site you're visiting from that. The process can be automated and can associate IP addresses with serial numbers. It is also possible to check [Certificate Transparency](https://en.wikipedia.org/wiki/Certificate_Transparency) logs for the serial number. | ||||
|  | ||||
| ## Should I use encrypted DNS? | ||||
|  | ||||
| We made this flow chart to describe when you *should* use encrypted DNS: | ||||
|  | ||||
| ``` mermaid | ||||
| graph TB | ||||
|     Start[Start] --> anonymous{Trying to be<br> anonymous?} | ||||
|     anonymous--> | Yes | tor(Use Tor) | ||||
|     anonymous --> | No | censorship{Avoiding<br> censorship?} | ||||
|     censorship --> | Yes | vpnOrTor(Use<br> VPN or Tor) | ||||
|     censorship --> | No | privacy{Want privacy<br> from ISP?} | ||||
|     privacy --> | Yes | vpnOrTor | ||||
|     privacy --> | No | obnoxious{ISP makes<br> obnoxious<br> redirects?} | ||||
|     obnoxious --> | Yes | encryptedDNS(Use<br> encrypted DNS<br> with 3rd party) | ||||
|     obnoxious --> | No | ispDNS{Does ISP support<br> encrypted DNS?} | ||||
|     ispDNS --> | Yes | useISP(Use<br> encrypted DNS<br> with ISP) | ||||
|     ispDNS --> | No | nothing(Do nothing) | ||||
| ``` | ||||
|  | ||||
| Encrypted DNS with a third-party should only be used to get around redirects and basic [DNS blocking](https://en.wikipedia.org/wiki/DNS_blocking) when you can be sure there won't be any consequences or you're interested in a provider that does some rudimentary filtering. | ||||
|  | ||||
| [List of recommended DNS servers](../dns.md){ .md-button } | ||||
|  | ||||
| ## What is DNSSEC? | ||||
|  | ||||
| [Domain Name System Security Extensions](https://en.wikipedia.org/wiki/Domain_Name_System_Security_Extensions) (DNSSEC) is a feature of DNS that authenticates responses to domain name lookups. It does not provide privacy protections for those lookups, but rather prevents attackers from manipulating or poisoning the responses to DNS requests. | ||||
|  | ||||
| In other words, DNSSEC digitally signs data to help ensure its validity. In order to ensure a secure lookup, the signing occurs at every level in the DNS lookup process. As a result, all answers from DNS can be trusted. | ||||
|  | ||||
| The DNSSEC signing process is similar to someone signing a legal document with a pen; that person signs with a unique signature that no one else can create, and a court expert can look at that signature and verify that the document was signed by that person. These digital signatures ensure that data has not been tampered with. | ||||
|  | ||||
| DNSSEC implements a hierarchical digital signing policy across all layers of DNS. For example, in the case of a `privacyguides.org` lookup, a root DNS server would sign a key for the `.org` nameserver, and the `.org` nameserver would then sign a key for `privacyguides.org`’s authoritative nameserver. | ||||
|  | ||||
| <small>Adapted from [DNS Security Extensions (DNSSEC) overview](https://cloud.google.com/dns/docs/dnssec) by Google and [DNSSEC: An Introduction](https://blog.cloudflare.com/dnssec-an-introduction) by Cloudflare, both licensed under [CC BY 4.0](https://creativecommons.org/licenses/by/4.0).</small> | ||||
|  | ||||
| ## What is QNAME minimization? | ||||
|  | ||||
| A QNAME is a "qualified name", for example `discuss.privacyguides.net`. In the past, when resolving a domain name your DNS resolver would ask every server in the chain to provide any information it has about your full query. In this example below, your request to find the IP address for `discuss.privacyguides.net` gets asked of every DNS server provider: | ||||
|  | ||||
| | Server                 | Question Asked                              | Response                                    | | ||||
| |------------------------|---------------------------------------------|---------------------------------------------| | ||||
| | Root server            | What's the IP of discuss.privacyguides.net? | I don't know, ask .net's server...          | | ||||
| | .net's server          | What's the IP of discuss.privacyguides.net? | I don't know, ask Privacy Guides' server... | | ||||
| | Privacy Guides' server | What's the IP of discuss.privacyguides.net? | 5.161.195.190!                              | | ||||
|  | ||||
| With "QNAME minimization," your DNS resolver now only asks for just enough information to find the next server in the chain. In this example, the root server is only asked for enough information to find the appropriate nameserver for the .net TLD, and so on, without ever knowing the full domain you're trying to visit: | ||||
|  | ||||
| | Server                 | Question Asked                                       | Response                          | | ||||
| |------------------------|------------------------------------------------------|-----------------------------------| | ||||
| | Root server            | What's the nameserver for .net?                      | *Provides .net's server*          | | ||||
| | .net's server          | What's the nameserver for privacyguides.net?         | *Provides Privacy Guides' server* | | ||||
| | Privacy Guides' server | What's the nameserver for discuss.privacyguides.net? | This server!                      | | ||||
| | Privacy Guides' server | What's the IP of discuss.privacyguides.net?          | 5.161.195.190                     | | ||||
|  | ||||
| While this process can be slightly more inefficient, in this example neither the central root nameservers nor the TLD's nameservers ever receive information about your *full* query, thus reducing the amount of information being transmitted about your browsing habits. Further technical description is defined in [RFC 7816](https://datatracker.ietf.org/doc/html/rfc7816). | ||||
|  | ||||
| ## What is EDNS Client Subnet (ECS)? | ||||
|  | ||||
| The [EDNS Client Subnet](https://en.wikipedia.org/wiki/EDNS_Client_Subnet) is a method for a recursive DNS resolver to specify a [subnetwork](https://en.wikipedia.org/wiki/Subnetwork) for the [host or client](https://en.wikipedia.org/wiki/Client_(computing)) which is making the DNS query. | ||||
|  | ||||
| It's intended to "speed up" delivery of data by giving the client an answer that belongs to a server that is close to them such as a [content delivery network](https://en.wikipedia.org/wiki/Content_delivery_network), which are often used in video streaming and serving JavaScript web apps. | ||||
|  | ||||
| This feature does come at a privacy cost, as it tells the DNS server some information about the client's location, generally your IP network. For example, if your IP address is `198.51.100.32` the DNS provider might share `198.51.100.0/24` with the authoritative server. Some DNS providers anonymize this data by providing another IP address which is approximately near your location. | ||||
|  | ||||
| If you have `dig` installed you can test whether your DNS provider gives EDNS information out to DNS nameservers with the following command: | ||||
|  | ||||
| ```bash | ||||
| dig +nocmd -t txt o-o.myaddr.l.google.com +nocomments +noall +answer +stats | ||||
| ``` | ||||
|  | ||||
| Note that this command will contact Google for the test, and return your IP as well as EDNS client subnet information. If you want to test another DNS resolver you can specify their IP, to test `9.9.9.11` for example: | ||||
|  | ||||
| ```bash | ||||
| dig +nocmd @9.9.9.11 -t txt o-o.myaddr.l.google.com +nocomments +noall +answer +stats | ||||
| ``` | ||||
|  | ||||
| If the results include a second edns0-client-subnet TXT record (like shown below), then your DNS server is passing along EDNS information. The IP or network shown after is the precise information which was shared with Google by your DNS provider. | ||||
|  | ||||
| ```text | ||||
| o-o.myaddr.l.google.com. 60 IN TXT "198.51.100.32" | ||||
| o-o.myaddr.l.google.com. 60 IN TXT "edns0-client-subnet 198.51.100.0/24" | ||||
| ;; Query time: 64 msec | ||||
| ;; SERVER: 9.9.9.11#53(9.9.9.11) | ||||
| ;; WHEN: Wed Mar 13 10:23:08 CDT 2024 | ||||
| ;; MSG SIZE  rcvd: 130 | ||||
| ``` | ||||
							
								
								
									
										86
									
								
								docs/advanced/payments.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,86 @@ | ||||
| --- | ||||
| title: Private Payments | ||||
| icon: material/hand-coin | ||||
| --- | ||||
| There's a reason data about your buying habits is considered the holy grail of ad targeting: your purchases can leak a veritable treasure trove of data about you. Unfortunately, the current financial system is anti-privacy by design, enabling banks, other companies, and governments to easily trace transactions. Nevertheless, you have plenty of options when it comes to making payments privately. | ||||
|  | ||||
| ## Cash | ||||
|  | ||||
| For centuries, **cash** has functioned as the primary form of private payment. Cash has excellent privacy properties in most cases, is widely accepted in most countries, and is **fungible**, meaning it is non-unique and completely interchangable. | ||||
|  | ||||
| Cash payment laws vary by country. In the United States, special disclosure is required for cash payments over $10,000 to the IRS on [Form 8300](https://irs.gov/businesses/small-businesses-self-employed/form-8300-and-reporting-cash-payments-of-over-10000). The receiving business is required to ID verify the payee’s name, address, occupation, date of birth, and Social Security Number or other TIN (with some exceptions). Lower limits without ID such as $3,000 or less exist for exchanges and money transmission. Cash also contains serial numbers. These are almost never tracked by merchants, but they can be used by law enforcement in targeted investigations. | ||||
|  | ||||
| Despite this, it’s typically the best option. | ||||
|  | ||||
| ## Prepaid Cards & Gift Cards | ||||
|  | ||||
| It’s relatively simple to purchase gift cards and prepaid cards at most grocery stores and convenience stores with cash. Gift cards usually don’t have a fee, though prepaid cards often do, so pay close attention to these fees and expiry dates. Some stores may ask to see your ID at checkout to reduce fraud. | ||||
|  | ||||
| Gift cards usually have limits of up to $200 per card, but some offer limits of up to $2,000 per card. Prepaid cards (eg: from Visa or Mastercard) usually have limits of up to $1,000 per card. | ||||
|  | ||||
| Gift cards have the downside of being subject to merchant policies, which can have terrible terms and restrictions. For example, some merchants don’t accept payment in gift cards exclusively, or they may cancel the value of the card if they consider you to be a high-risk user. Once you have merchant credit, the merchant has a strong degree of control over this credit. | ||||
|  | ||||
| Prepaid cards don’t allow cash withdrawals from ATMs or “peer-to-peer” payments in Venmo and similar apps. | ||||
|  | ||||
| Cash remains the best option for in-person purchases for most people. Gift cards can be useful for the savings they bring. Prepaid cards can be useful for places that don’t accept cash. Gift cards and prepaid cards are easier to use online than cash, and they are easier to acquire with cryptocurrencies than cash. | ||||
|  | ||||
| ### Online Marketplaces | ||||
|  | ||||
| If you have [cryptocurrency](../cryptocurrency.md), you can purchase gift cards with an online gift card marketplace. Some of these services offer ID verification options for higher limits, but they also allow accounts with just an email address. Basic limits start at $5,000-10,000 a day for basic accounts, and significantly higher limits for ID verified accounts (if offered). | ||||
|  | ||||
| When buying gift cards online, there is usually a slight discount. Prepaid cards are usually sold online at face value or with a fee. If you buy prepaid cards and gift cards with cryptocurrencies, you should strongly prefer to pay with Monero which provides strong privacy, more on this below. Paying for a gift card with a traceable payment method negates the benefits a gift card can provide when purchased with cash or Monero. | ||||
|  | ||||
| - [Online Gift Card Marketplaces :material-arrow-right-drop-circle:](../financial-services.md#gift-card-marketplaces) | ||||
|  | ||||
| ## Virtual Cards | ||||
|  | ||||
| Another way to protect your information from merchants online is to use virtual, single-use cards which mask your actual banking or billing information. This is primarily useful for protecting you from merchant data breaches, less sophisticated tracking or purchase correlation by marketing agencies, and online data theft. They do **not** assist you in making a purchase completely anonymously, nor do they hide any information from the banking institution themselves. Regular financial institutions which offer virtual cards are subject to "Know Your Customer" (KYC) laws, meaning they may require your ID or other identifying information. | ||||
|  | ||||
| - [Recommended Payment Masking Services :material-arrow-right-drop-circle:](../financial-services.md#payment-masking-services) | ||||
|  | ||||
| These tend to be good options for recurring/subscription payments online, while prepaid gift cards are preferred for one-time transactions. | ||||
|  | ||||
| ## Cryptocurrency | ||||
|  | ||||
| Cryptocurrencies are a digital form of currency designed to work without central authorities such as a government or bank. While *some* cryptocurrency projects can allow you to make private transactions online, many use a public blockchain which does not provide any transaction privacy. Cryptocurrencies also tend to be very volatile assets, meaning their value can change rapidly and significantly at any time. As such, we generally don't recommend using cryptocurrency as a long-term store of value. If you decide to use cryptocurrency online, make sure you have a full understanding of its privacy aspects beforehand, and only invest amounts which would not be disastrous to lose. | ||||
|  | ||||
| <div class="admonition danger" markdown> | ||||
| <p class="admonition-title">Danger</p> | ||||
|  | ||||
| The vast majority of cryptocurrencies operate on a **public** blockchain, meaning that every transaction is public knowledge. This includes even most well-known cryptocurrencies like Bitcoin and Ethereum. Transactions with these cryptocurrencies should not be considered private and will not protect your anonymity. | ||||
|  | ||||
| Additionally, many if not most cryptocurrencies are scams. Make transactions carefully with only projects you trust. | ||||
|  | ||||
| </div> | ||||
|  | ||||
| ### Privacy Coins | ||||
|  | ||||
| There are a number of cryptocurrency projects which purport to provide privacy by making transactions anonymous. We recommend using one which provides transaction anonymity **by default** to avoid operational errors. | ||||
|  | ||||
| - [Recommended Cryptocurrency :material-arrow-right-drop-circle:](../cryptocurrency.md#coins) | ||||
|  | ||||
| Privacy coins have been subject to increasing scrutiny by government agencies. In 2020, [the IRS published a $625,000 bounty](https://forbes.com/sites/kellyphillipserb/2020/09/14/irs-will-pay-up-to-625000-if-you-can-crack-monero-other-privacy-coins/?sh=2e9808a085cc) for tools which can break Bitcoin Lightning Network and/or Monero's transaction privacy. They ultimately [paid two companies](https://sam.gov/opp/5ab94eae1a8d422e88945b64181c6018/view) (Chainalysis and Integra Fec) a combined $1.25 million for tools which purport to do so (it is unknown which cryptocurrency network these tools target). Due to the secrecy surrounding tools like these, ==none of these methods of tracing cryptocurrencies have been independently confirmed.== However, it is quite likely that tools which assist targeted investigations into private coin transactions exist, and that privacy coins only succeed in thwarting mass surveillance. | ||||
|  | ||||
| ### Other Coins (Bitcoin, Ethereum, etc.) | ||||
|  | ||||
| The vast majority of cryptocurrency projects use a public blockchain, meaning that all transactions are both easily traceable and permanent. As such, we strongly discourage the use of most cryptocurrency for privacy-related reasons. | ||||
|  | ||||
| Anonymous transactions on a public blockchain are *theoretically* possible, and the Bitcoin wiki [gives one example of a "completely anonymous" transaction](https://en.bitcoin.it/wiki/Privacy#Example_-_A_perfectly_private_donation). However, doing so requires a complicated setup involving Tor and "solo-mining" a block to generate completely independent cryptocurrency, a practice which has not been practical for nearly any enthusiast for many years. | ||||
|  | ||||
| ==Your best option is to avoid these cryptocurrencies entirely and stick with one which provides privacy by default.== Attempting to use other cryptocurrency is outside the scope of this site and strongly discouraged. | ||||
|  | ||||
| ### Wallet Custody | ||||
|  | ||||
| With cryptocurrency there are two forms of wallets: custodial wallets and noncustodial wallets. Custodial wallets are operated by centralized companies/exchanges, where the private key for your wallet is held by that company, and you can access them anywhere typically with a regular username and password. Noncustodial wallets are wallets where you control and manage the private keys to access it. Assuming you keep your wallet's private keys secured and backed up, noncustodial wallets provide greater security and censorship-resistance over custodial wallets, because your cryptocurrency can't be stolen or frozen by a company with custody over your private keys. Key custody is especially important when it comes to privacy coins: Custodial wallets grant the operating company the ability to view your transactions, negating the privacy benefits of those cryptocurrencies. | ||||
|  | ||||
| ### Acquisition | ||||
|  | ||||
| Acquiring [cryptocurrencies](../cryptocurrency.md) like Monero privately can be difficult. P2P marketplaces like [LocalMonero](https://localmonero.co), a platform which facilitates trades between people, are one option that can be used. If using an exchange which requires KYC is an acceptable risk for you as long as subsequent transactions can't be traced, a much easier option is to purchase Monero on an exchange like [Kraken](https://kraken.com), or purchase Bitcoin/Litecoin from a KYC exchange which can then be swapped for Monero. Then, you can withdraw the purchased Monero to your own noncustodial wallet to use privately from that point forward. | ||||
|  | ||||
| If you go this route, make sure to purchase Monero at different times and in different amounts than where you will spend it. If you purchase $5000 of Monero at an exchange and make a $5000 purchase in Monero an hour later, those actions could potentially be correlated by an outside observer regardless of which path the Monero took. Staggering purchases and purchasing larger amounts of Monero in advance to later spend on multiple smaller transactions can avoid this pitfall. | ||||
|  | ||||
| ## Additional Considerations | ||||
|  | ||||
| When you're making a payment in-person with cash, make sure to keep your in-person privacy in mind. Security cameras are ubiquitous. Consider wearing non-distinct clothing and a face mask (such as a surgical mask or N95). Don’t sign up for rewards programs or provide any other information about yourself. | ||||
|  | ||||
| When purchasing online, ideally you should do so over [Tor](tor-overview.md). However, many merchants don’t allow purchases with Tor. You can consider using a [recommended VPN](../vpn.md) (paid for with cash, gift card, or Monero), or making the purchase from a coffee shop or library with free Wi-Fi. If you are ordering a physical item that needs to be delivered, you will need to provide a delivery address. You should consider using a PO box, private mailbox, or work address. | ||||
							
								
								
									
										198
									
								
								docs/advanced/tor-overview.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,198 @@ | ||||
| --- | ||||
| title: "Tor Overview" | ||||
| icon: 'simple/torproject' | ||||
| description: Tor is a free to use, decentralized network designed for using the internet with as much privacy as possible. | ||||
| --- | ||||
|  | ||||
| Tor is a free to use, decentralized network designed for using the internet with as much privacy as possible. If used properly, the network enables private and anonymous browsing and communications. | ||||
|  | ||||
| ## Safely Connecting to Tor | ||||
|  | ||||
| Before connecting to [Tor](../tor.md), you should carefully consider what you're looking to accomplish by using Tor in the first place, and who you're trying to hide your network activity from. | ||||
|  | ||||
| If you live in a free country, are accessing mundane content via Tor, aren't worried about your ISP or local network administrators having the knowledge that you're using Tor, and want to help [de-stigmatize](https://2019.www.torproject.org/about/torusers.html.en) Tor usage, you can likely connect to Tor directly via standard means like [Tor Browser](../tor.md) without worry. | ||||
|  | ||||
| If you have the ability to access a trusted VPN provider and **any** of the following are true, you almost certainly should connect to Tor through a VPN: | ||||
|  | ||||
| - You already use a [trusted VPN provider](../vpn.md) | ||||
| - Your threat model includes an adversary which is capable of extracting information from your ISP | ||||
| - Your threat model includes your ISP itself as an adversary | ||||
| - Your threat model includes local network administrators before your ISP as an adversary | ||||
|  | ||||
| Because we already [generally recommend](../basics/vpn-overview.md) that the vast majority of people use a trusted VPN provider for a variety of reasons, the following recommendation about connecting to Tor via a VPN likely applies to you. <mark>There is no need to disable your VPN before connecting to Tor</mark>, as some online resources would lead you to believe. | ||||
|  | ||||
| Connecting directly to Tor will make your connection stand out to any local network administrators or your ISP. Detecting and correlating this traffic [has been done](https://edition.cnn.com/2013/12/17/justice/massachusetts-harvard-hoax) in the past by network administrators to identify and deanonymize specific Tor users on their network. On the other hand, connecting to a VPN is almost always less suspicious, because commercial VPN providers are used by everyday consumers for a variety of mundane tasks like bypassing geo-restrictions, even in countries with heavy internet restrictions. | ||||
|  | ||||
| Therefore, you should make an effort to hide your IP address **before** connecting to the Tor network. You can do this by simply connecting to a VPN (through a client installed on your computer) and then accessing [Tor](../tor.md) as normal, through Tor Browser for example. This creates a connection chain like: | ||||
|  | ||||
| - [x] You → VPN → Tor → Internet | ||||
|  | ||||
| From your ISP's perspective, it looks like you're accessing a VPN normally (with the associated cover that provides you). From your VPN's perspective, they can see that you are connecting to the Tor network, but nothing about what websites you're accessing. From Tor's perspective, you're connecting normally, but in the unlikely event of some sort of Tor network compromise, only your VPN's IP would be exposed, and your VPN would *additionally* have to be compromised to deanonymize you. | ||||
|  | ||||
| This is **not** censorship circumvention advice, because if Tor is blocked entirely by your ISP, your VPN likely is as well. Rather, this recommendation aims to make your traffic blend in better with commonplace VPN user traffic, and provide you with some level of plausible deniability by obscuring the fact that you're connecting to Tor from your ISP. | ||||
|  | ||||
| --- | ||||
|  | ||||
| We **very strongly discourage** combining Tor with a VPN in any other manner. Do not configure your connection in a way which resembles any of the following: | ||||
|  | ||||
| - You → Tor → VPN → Internet | ||||
| - You → VPN → Tor → VPN → Internet | ||||
| - Any other configuration | ||||
|  | ||||
| Some VPN providers and other publications will occasionally recommend these **bad** configurations to evade Tor bans (exit nodes being blocked by websites) in some places. [Normally](https://support.torproject.org/#about_change-paths), Tor frequently changes your circuit path through the network. When you choose a permanent *destination* VPN (connecting to a VPN server *after* Tor), you're eliminating this advantage and drastically harming your anonymity. | ||||
|  | ||||
| Setting up bad configurations like these is difficult to do accidentally, because it usually involves either setting up custom proxy settings inside Tor Browser, or setting up custom proxy settings inside your VPN client which routes your VPN traffic through the Tor Browser. As long as you avoid these non-default configurations, you're probably fine. | ||||
|  | ||||
| --- | ||||
|  | ||||
| <div class="admonition info" markdown> | ||||
| <p class="admonition-title">VPN/SSH Fingerprinting</p> | ||||
|  | ||||
| The Tor Project [notes](https://gitlab.torproject.org/legacy/trac/-/wikis/doc/TorPlusVPN#vpnssh-fingerprinting) that *theoretically* using a VPN to hide Tor activities from your ISP may not be foolproof. VPNs have been found to be vulnerable to website traffic fingerprinting, where an adversary can still guess what website is being visited, because all websites have specific traffic patterns. | ||||
|  | ||||
| Therefore, it's not unreasonable to believe that encrypted Tor traffic hidden by a VPN could also be detected via similar methods. There are no research papers on this subject, and we still consider the benefits of using a VPN to far outweigh these risks, but it is something to keep in mind. | ||||
|  | ||||
| If you still believe that pluggable transports (bridges) provide additional protection against website traffic fingerprinting that a VPN does not, you always have the option to use a bridge **and** a VPN in conjunction. | ||||
|  | ||||
| </div> | ||||
|  | ||||
| Determining whether you should first use a VPN to connect to the Tor network will require some common sense and knowledge of your own government's and ISP's policies relating to what you're connecting to. However, again in most cases you will be better off being seen as connecting to a commercial VPN network than directly to the Tor network. If VPN providers are censored in your area, then you can also consider using Tor pluggable transports (e.g. Snowflake or meek bridges) as an alternative, but using these bridges may arouse more suspicion than standard WireGuard/OpenVPN tunnels. | ||||
|  | ||||
| ## What Tor is Not | ||||
|  | ||||
| The Tor network is not the perfect privacy protection tool in all cases, and has a number of drawbacks which should be carefully considered. These things should not discourage you from using Tor if it is appropriate for your needs, but they are still things to think about when deciding which solution is most appropriate for you. | ||||
|  | ||||
| ### Tor is not a free VPN | ||||
|  | ||||
| The release of the *Orbot* mobile app has lead many people to describe Tor as a "free VPN" for all of your device traffic. However, treating Tor like this poses some dangers compared to a typical VPN. | ||||
|  | ||||
| Unlike Tor exit nodes, VPN providers are usually not *actively* [malicious](#caveats). Because Tor exit nodes can be created by anybody, they are hotspots for network logging and modification. In 2020, many Tor exit nodes were documented to be downgrading HTTPS traffic to HTTP in order to [hijack cryptocurrency transactions](https://therecord.media/thousands-of-tor-exit-nodes-attacked-cryptocurrency-users-over-the-past-year). Other exit node attacks such as replacing downloads via unencrypted channels with malware have also been observed. HTTPS does mitigate these threats to an extent. | ||||
|  | ||||
| As we've alluded to already, Tor is also easily identifiable on the network. Unlike an actual VPN provider, using Tor will make you stick out as a person likely attempting to evade authorities. In a perfect world, Tor would be seen by network administrators and authorities as a tool with many uses (like how VPNs are viewed), but in reality the perception of Tor is still far less legitimate than the perception of commercial VPNs, so using a real VPN provides you with plausible deniability, e.g. "I was just using it to watch Netflix," etc. | ||||
|  | ||||
| ### Tor usage is not undetectable | ||||
|  | ||||
| **Even if you use bridges and pluggable transports,** the Tor Project provides no tools to hide the fact that you are using Tor from your ISP. Even using obfuscated "pluggable transports" or non-public bridges do not hide the fact that you are using a private communications channel. The most popular pluggable transports like obfs4 (which obfuscates your traffic to "look like nothing") and meek (which uses domain fronting to camouflage your traffic) can be [detected](https://hackerfactor.com/blog/index.php?/archives/889-Tor-0day-Burning-Bridges.html) with fairly standard traffic analysis techniques. Snowflake has similar issues, and can be [easily detected](https://hackerfactor.com/blog/index.php?/archives/944-Tor-0day-Snowflake.html) *before* a Tor connection is even established. | ||||
|  | ||||
| Pluggable transports other than these three do exist, but typically rely on security through obscurity to evade detection. They aren't impossible to detect, they are just used by so few people that it's not worth the effort building detectors for them. They shouldn't be relied upon if you specifically are being monitored. | ||||
|  | ||||
| It is critical to understand the difference between bypassing censorship and evading detection. It is easier to accomplish the former because of the many real-world limitations on what network censors can realistically do en masse, but these techniques do not hide the fact that you—*specifically* you—are using Tor from an interested party monitoring your network. | ||||
|  | ||||
| ### Tor Browser is not the most *secure* browser | ||||
|  | ||||
| Anonymity can often be at odds with security: Tor's anonymity requires every user to be identical, which creates a monoculture (the same bugs are present across all Tor Browser users). As a cybersecurity rule of thumb, monocultures are generally regarded as bad: Security through diversity (which Tor lacks) provides natural segmentation by limiting vulnerabilities to smaller groups, and is therefore usually desirable, but this diversity is also less good for anonymity. | ||||
|  | ||||
| Additionally, Tor Browser is based on Firefox's Extended Support Release builds, which only receives patches for vulnerabilities considered *Critical* and *High* (not *Medium* and *Low*). This means that attackers could (for example): | ||||
|  | ||||
| 1. Look for new Critical/High vulnerabilities in Firefox nightly or beta builds, then check if they are exploitable in Tor Browser (this vulnerability period can last weeks). | ||||
| 2. Chain *multiple* Medium/Low vulnerabilities together until they get the level of access they're looking for (this vulnerability period can last months or longer). | ||||
|  | ||||
| Those at risk of browser vulnerabilities should consider additional protections to defend against Tor Browser exploits, such as using Whonix in [Qubes](../os/qubes-overview.md) to contain your Tor browsing in a secure VM and protect against leaks. | ||||
|  | ||||
| ## Path Building to Clearnet Services | ||||
|  | ||||
| "Clearnet services" are websites which you can access with any browser, like [privacyguides.org](https://www.privacyguides.org). Tor lets you connect to these websites anonymously by routing your traffic through a network comprised of thousands of volunteer-run servers called nodes (or relays). | ||||
|  | ||||
| Every time you [connect to Tor](../tor.md), it will choose three nodes to build a path to the internet—this path is called a "circuit." | ||||
|  | ||||
| <figure markdown> | ||||
|    | ||||
|    | ||||
|   <figcaption>Tor circuit pathway</figcaption> | ||||
| </figure> | ||||
|  | ||||
| Each of these nodes has its own function: | ||||
|  | ||||
| ### The Entry Node | ||||
|  | ||||
| The entry node, often called the guard node, is the first node to which your Tor client connects. The entry node is able to see your IP address, however it is unable to see what you are connecting to. | ||||
|  | ||||
| Unlike the other nodes, the Tor client will randomly select an entry node and stick with it for two to three months to protect you from certain attacks.[^1] | ||||
|  | ||||
| [^1]: The first relay in your circuit is called an "entry guard" or "guard". It is a fast and stable relay that remains the first one in your circuit for 2-3 months in order to protect against a known anonymity-breaking attack. The rest of your circuit changes with every new website you visit, and all together these relays provide the full privacy protections of Tor. For more information on how guard relays work, see this [blog post](https://blog.torproject.org/improving-tors-anonymity-changing-guard-parameters) and [paper](https://www-users.cs.umn.edu/~hoppernj/single_guard.pdf) on entry guards. ([https://support.torproject.org/tbb/tbb-2/](https://support.torproject.org/tbb/tbb-2)) | ||||
|  | ||||
| ### The Middle Node | ||||
|  | ||||
| The middle node is the second node to which your Tor client connects. It can see which node the traffic came from—the entry node—and to which node it goes to next. The middle node cannot, see your IP address or the domain you are connecting to. | ||||
|  | ||||
| For each new circuit, the middle node is randomly selected out of all available Tor nodes. | ||||
|  | ||||
| ### The Exit Node | ||||
|  | ||||
| The exit node is the point in which your web traffic leaves the Tor network and is forwarded to your desired destination. The exit node is unable to see your IP address, but it does know what site it's connecting to. | ||||
|  | ||||
| The exit node will be chosen at random from all available Tor nodes ran with an exit relay flag.[^2] | ||||
|  | ||||
| [^2]: Relay flag: a special (dis-)qualification of relays for circuit positions (for example, "Guard", "Exit", "BadExit"), circuit properties (for example, "Fast", "Stable"), or roles (for example, "Authority", "HSDir"), as assigned by the directory authorities and further defined in the directory protocol specification. ([https://metrics.torproject.org/glossary.html](https://metrics.torproject.org/glossary.html)) | ||||
|  | ||||
| ## Path Building to Onion Services | ||||
|  | ||||
| "Onion Services" (also commonly referred to as "hidden services") are websites which can only be accessed by the Tor browser. These websites have a long randomly generated domain name ending with `.onion`. | ||||
|  | ||||
| Connecting to an Onion Service in Tor works very similarly to connecting to a clearnet service, but your traffic is routed through a total of **six** nodes before reaching the destination server. Just like before however, only three of these nodes are contributing to *your* anonymity, the other three nodes protect *the Onion Service's* anonymity, hiding the website's true IP and location in the same manner that Tor Browser is hiding yours. | ||||
|  | ||||
| <figure style="width:100%" markdown> | ||||
|    | ||||
|    | ||||
|   <figcaption>Tor circuit pathway with Onion Services. Nodes in the <span class="pg-blue">blue</span> fence belong to your browser, while nodes in the <span class="pg-red">red</span> fence belong to the server, so their identity is hidden from you.</figcaption> | ||||
| </figure> | ||||
|  | ||||
| ## Encryption | ||||
|  | ||||
| Tor encrypts each packet (a block of transmitted data) three times with the keys from the exit, middle, and entry node—in that order. | ||||
|  | ||||
| Once Tor has built a circuit, data transmission is done as follows: | ||||
|  | ||||
| 1. Firstly: when the packet arrives at the entry node, the first layer of encryption is removed. In this encrypted packet, the entry node will find another encrypted packet with the middle node’s address. The entry node will then forward the packet to the middle node. | ||||
|  | ||||
| 2. Secondly: when the middle node receives the packet from the entry node, it too will remove a layer of encryption with its key, and this time finds an encrypted packet with the exit node's address. The middle node will then forward the packet to the exit node. | ||||
|  | ||||
| 3. Lastly: when the exit node receives its packet, it will remove the last layer of encryption with its key. The exit node will see the destination address and forward the packet to that address. | ||||
|  | ||||
| Below is an alternative diagram showing the process. Each node removes its own layer of encryption, and when the destination server returns data, the same process happens entirely in reverse. For example, the exit node does not know who you are, but it does know which node it came from, and so it adds its own layer of encryption and sends it back. | ||||
|  | ||||
| <figure markdown> | ||||
|    | ||||
|    | ||||
|   <figcaption>Sending and receiving data through the Tor Network</figcaption> | ||||
| </figure> | ||||
|  | ||||
| Tor allows us to connect to a server without any single party knowing the entire path. The entry node knows who you are, but not where you are going; the middle node doesn’t know who you are or where you are going; and the exit node knows where you are going, but not who you are. Because the exit node is what makes the final connection, the destination server will never know your IP address. | ||||
|  | ||||
| ## Caveats | ||||
|  | ||||
| Though Tor does provide strong privacy guarantees, one must be aware that Tor is not perfect: | ||||
|  | ||||
| - Tor never protects you from exposing yourself by mistake, such as if you share too much information about your real identity. | ||||
| - Tor exit nodes can **modify** unencrypted traffic which passes through them. This means traffic which is not encrypted, such as plain HTTP traffic, can be changed by a malicious exit node. **Never** download files from an unencrypted `http://` website over Tor, and ensure your browser is set to always upgrade HTTP traffic to HTTPS. | ||||
| - Tor exit nodes can also monitor traffic that passes through them. Unencrypted traffic which contains personally identifiable information can deanonymize you to that exit node. Again, we recommend only using HTTPS over Tor. | ||||
| - Powerful adversaries with the capability to passively watch *all* network traffic around the globe ("Global Passive Adversaries") are **not** something that Tor protects you against (and using Tor [with a VPN](#safely-connecting-to-tor) doesn't change this fact). | ||||
| - Well-funded adversaries with the capability to passively watch *most* network traffic around the globe still have a *chance* of deanonymizing Tor users by means of advanced traffic analysis. | ||||
|  | ||||
| If you wish to use Tor for browsing the web, we only recommend the **official** Tor Browser—it is designed to prevent fingerprinting. | ||||
|  | ||||
| - [Tor Browser :material-arrow-right-drop-circle:](../tor.md#tor-browser) | ||||
|  | ||||
| ### Protections provided by bridges | ||||
|  | ||||
| Tor bridges are commonly touted as an alternative method to hiding Tor usage from an ISP, instead of a VPN (as we suggest using if possible). Something to consider is that while bridges may provide adequate censorship circumvention, this is only a *transient* benefit. They do not adequately protect you from your ISP discovering you connected to Tor in the *past* with historical traffic log analysis. | ||||
|  | ||||
| To illustrate this point, consider the following scenario: You connect to Tor via a bridge, and your ISP doesn’t detect it because they are not doing sophisticated analysis of your traffic, so things are working as intended. Now, 4 months go by, and the IP of your bridge has been made public. This is a very common occurrence with bridges, they are discovered and blocked relatively frequently, just not immediately. | ||||
|  | ||||
| Your ISP wants to identify Tor users 4 months ago, and with their limited metadata logging they can see that you connected to an IP address which was later revealed to be a Tor bridge. You have virtually no other excuse to be making such a connection, so the ISP can say with very high confidence that you were a Tor user at that time. | ||||
|  | ||||
| Contrast this with our recommended scenario, where you connect to Tor via a VPN. Say that 4 months later your ISP again wants to identify anybody who used Tor 4 months ago. Their logs almost certainly can identify your traffic 4 months ago, but all they would likely be able to see is that you connected to a VPN’s IP address. This is because most ISPs only retain metadata over long periods of time, not the full contents of the traffic you request. Storing the entirety of your traffic data would require a massive quantity of storage which nearly all threat actors wouldn't possess. | ||||
|  | ||||
| Because your ISP almost certainly is not capturing all packet-level data and storing it forever, they have no way of determining what you connected to with that VPN *after* the fact with an advanced technique like deep packet inspection, and therefore you have plausible deniability. | ||||
|  | ||||
| Therefore, bridges provide the most benefit when circumventing internet censorship *in the moment*, but they are not an adequate substitute for **all** the benefits that using a VPN alongside Tor can provide. Again, this is not advice *against* using Tor bridges, you should just be aware of these limitations while making your decision. In some cases bridges may be the *only* option (if all VPN providers are blocked, for instance), so you can still use them in those circumstances with this limitation in mind. | ||||
|  | ||||
| If you think that a bridge can aid in defending against fingerprinting or other advanced network analysis more than a VPN's encrypted tunnel already can, you always have the option to use a bridge in conjunction with a VPN as well. That way you are still protected by the pluggable transport's obfuscation techniques even if an adversary gains some level of visibility into your VPN tunnel. If you decide to go this route, we recommend connecting to an obfs4 bridge behind your VPN for optimal fingerprinting protection, rather than meek or Snowflake. | ||||
|  | ||||
| It is [possible](https://discuss.privacyguides.net/t/clarify-tors-weaknesses-with-respect-to-observability/3676/16) that the [WebTunnel](https://forum.torproject.org/t/tor-relays-announcement-webtunnel-a-new-pluggable-transport-for-bridges-now-available-for-deployment/8180) pluggable transport currently being trialed may mitigate some of these concerns. We will continue to keep an eye on that technology as it develops. | ||||
|  | ||||
| ## Additional Resources | ||||
|  | ||||
| - [Tor Browser User Manual](https://tb-manual.torproject.org) | ||||
| - [How Tor Works - Computerphile](https://invidious.privacyguides.net/embed/QRYzre4bf7I?local=true) <small>(YouTube)</small> | ||||
| - [Tor Onion Services - Computerphile](https://invidious.privacyguides.net/embed/lVcbq_a5N9I?local=true) <small>(YouTube)</small> | ||||
							
								
								
									
										557
									
								
								docs/android.md
									
									
									
									
									
								
							
							
						
						| @@ -1,200 +1,274 @@ | ||||
| --- | ||||
| icon: 'fontawesome/brands/android' | ||||
| meta_title: "Android Recommendations: GrapheneOS and DivestOS - Privacy Guides" | ||||
| title: "Android" | ||||
| icon: 'simple/android' | ||||
| description: You can replace the operating system on your Android phone with these secure and privacy-respecting alternatives. | ||||
| cover: android.webp | ||||
| schema: | ||||
|   - | ||||
|     "@context": http://schema.org | ||||
|     "@type": WebPage | ||||
|     name: Private Android Operating Systems | ||||
|     url: "./" | ||||
|   - | ||||
|     "@context": http://schema.org | ||||
|     "@type": CreativeWork | ||||
|     name: Android | ||||
|     image: /assets/img/android/android.svg | ||||
|     url: https://source.android.com/ | ||||
|     sameAs: https://en.wikipedia.org/wiki/Android_(operating_system) | ||||
|   - | ||||
|     "@context": http://schema.org | ||||
|     "@type": CreativeWork | ||||
|     name: GrapheneOS | ||||
|     image: /assets/img/android/grapheneos.svg | ||||
|     url: https://grapheneos.org/ | ||||
|     sameAs: https://en.wikipedia.org/wiki/GrapheneOS | ||||
|     subjectOf: | ||||
|       "@context": http://schema.org | ||||
|       "@type": WebPage | ||||
|       url: "./" | ||||
|   - | ||||
|     "@context": http://schema.org | ||||
|     "@type": CreativeWork | ||||
|     name: Divest | ||||
|     image: /assets/img/android/divestos.svg | ||||
|     url: https://divestos.org/ | ||||
|     sameAs: https://en.wikipedia.org/wiki/DivestOS | ||||
|     subjectOf: | ||||
|       "@context": http://schema.org | ||||
|       "@type": WebPage | ||||
|       url: "./" | ||||
|   - | ||||
|     "@context": http://schema.org | ||||
|     "@type": Product | ||||
|     name: Pixel | ||||
|     brand: | ||||
|       "@type": Brand | ||||
|       name: Google | ||||
|     image: /assets/img/android/google-pixel.png | ||||
|     sameAs: https://en.wikipedia.org/wiki/Google_Pixel | ||||
|     review: | ||||
|       "@type": Review | ||||
|       author: | ||||
|         "@type": Organization | ||||
|         name: Privacy Guides | ||||
|   - | ||||
|     "@context": http://schema.org | ||||
|     "@type": MobileApplication | ||||
|     name: Shelter | ||||
|     applicationCategory: Utilities | ||||
|     operatingSystem: Android | ||||
|   - | ||||
|     "@context": http://schema.org | ||||
|     "@type": MobileApplication | ||||
|     name: Auditor | ||||
|     applicationCategory: Utilities | ||||
|     operatingSystem: Android | ||||
|   - | ||||
|     "@context": http://schema.org | ||||
|     "@type": MobileApplication | ||||
|     name: Secure Camera | ||||
|     applicationCategory: Utilities | ||||
|     operatingSystem: Android | ||||
|   - | ||||
|     "@context": http://schema.org | ||||
|     "@type": MobileApplication | ||||
|     name: Secure PDF Viewer | ||||
|     applicationCategory: Utilities | ||||
|     operatingSystem: Android | ||||
| --- | ||||
| Android is a secure operating system that has strong [app sandboxing](https://source.android.com/security/app-sandbox), [Verified Boot](https://source.android.com/security/verifiedboot), and a robust [permission](https://developer.android.com/guide/topics/permissions/overview) control system. | ||||
|  | ||||
| The main privacy concern with most Android devices is that they usually include [Google Play Services](https://developers.google.com/android/guides/overview). This component is proprietary, [closed source](https://en.wikipedia.org/wiki/Proprietary_software), has a privileged role on your phone, and may collect private user information. It is neither a part of the [Android Open Source Project](https://source.android.com/) (AOSP) nor is it included with the below derivatives. | ||||
| { align=right } | ||||
|  | ||||
| The **Android Open Source Project** is an open-source mobile operating system led by Google which powers the majority of the world's mobile devices. Most phones sold with Android are modified to include invasive integrations and apps such as Google Play Services, so you can significantly improve your privacy on your mobile device by replacing your phone's default installation with a version of Android without these invasive features. | ||||
|  | ||||
| [:octicons-home-16:](https://source.android.com){ .card-link title=Homepage } | ||||
| [:octicons-info-16:](https://source.android.com/docs){ .card-link title=Documentation} | ||||
| [:octicons-code-16:](https://cs.android.com/android/platform/superproject){ .card-link title="Source Code" } | ||||
|  | ||||
| These are the Android operating systems, devices, and apps we recommend to maximize your mobile device's security and privacy. To learn more about Android: | ||||
|  | ||||
| [General Android Overview :material-arrow-right-drop-circle:](os/android-overview.md){ .md-button } | ||||
|  | ||||
| ## AOSP Derivatives | ||||
|  | ||||
| We recommend installing one of these custom Android operating systems on your device, listed in order of preference, depending on your device's compatibility with these operating systems. | ||||
|  | ||||
| <div class="admonition note" markdown> | ||||
| <p class="admonition-title">Note</p> | ||||
|  | ||||
| End-of-life devices (such as GrapheneOS or CalyxOS's "extended support" devices) do not have full security patches (firmware updates) due to the OEM discontinuing support. These devices cannot be considered completely secure regardless of installed software. | ||||
|  | ||||
| </div> | ||||
|  | ||||
| ### GrapheneOS | ||||
|  | ||||
| !!! recommendation | ||||
| <div class="admonition recommendation" markdown> | ||||
|  | ||||
|     { align=right } | ||||
|     { align=right } | ||||
| { align=right } | ||||
| { align=right } | ||||
|  | ||||
|     **GrapheneOS** is the best choice when it comes to privacy and security. | ||||
| **GrapheneOS** is the best choice when it comes to privacy and security. | ||||
|  | ||||
|     GrapheneOS provides additional [security hardening](https://en.wikipedia.org/wiki/Hardening_(computing)) and privacy improvements. It has a [hardened memory allocator](https://github.com/GrapheneOS/hardened_malloc), network and sensor permissions, and various other [security features](https://grapheneos.org/features). GrapheneOS also comes with full firmware updates and signed builds, so [verified boot](https://source.android.com/security/verifiedboot) is fully supported. | ||||
| GrapheneOS provides additional [security hardening](https://en.wikipedia.org/wiki/Hardening_(computing)) and privacy improvements. It has a [hardened memory allocator](https://github.com/GrapheneOS/hardened_malloc), network and sensor permissions, and various other [security features](https://grapheneos.org/features). GrapheneOS also comes with full firmware updates and signed builds, so verified boot is fully supported. | ||||
|  | ||||
|     [Visit grapheneos.org](https://grapheneos.org/){ .md-button .md-button--primary } [Privacy Policy](https://grapheneos.org/faq#privacy-policy){ .md-button } | ||||
| [:octicons-home-16: Homepage](https://grapheneos.org){ .md-button .md-button--primary } | ||||
| [:octicons-eye-16:](https://grapheneos.org/faq#privacy-policy){ .card-link title="Privacy Policy" } | ||||
| [:octicons-info-16:](https://grapheneos.org/faq){ .card-link title=Documentation} | ||||
| [:octicons-code-16:](https://grapheneos.org/source){ .card-link title="Source Code" } | ||||
| [:octicons-heart-16:](https://grapheneos.org/donate){ .card-link title=Contribute } | ||||
|  | ||||
| Notably, GrapheneOS supports [Sandboxed Google Play](https://grapheneos.org/usage#sandboxed-google-play). Google Play Services can be run fully sandboxed like a regular user app and contained in a work profile or user [profile](/android/#android-security-privacy) of your choice. This means that you can run apps dependant on Play Services, such as those that require push notifications using Google's [Firebase Cloud Messaging](https://firebase.google.com/docs/cloud-messaging/) service. GrapheneOS allows you to take advantage of most [Google Play Services](https://en.wikipedia.org/wiki/Google_Play_Services) whilst having full user control over their permissions and access. | ||||
| </div> | ||||
|  | ||||
| Currently, only [Pixel phones](https://grapheneos.org/faq#device-support) meet its hardware security requirement and are supported. | ||||
| GrapheneOS supports [Sandboxed Google Play](https://grapheneos.org/usage#sandboxed-google-play), which runs [Google Play Services](https://en.wikipedia.org/wiki/Google_Play_Services) fully sandboxed like any other regular app. This means you can take advantage of most Google Play Services, such as [push notifications](https://firebase.google.com/docs/cloud-messaging), while giving you full control over their permissions and access, and while containing them to a specific [work profile](os/android-overview.md#work-profile) or [user profile](os/android-overview.md#user-profiles) of your choice. | ||||
|  | ||||
| !!! attention | ||||
| Google Pixel phones are the only devices that currently meet GrapheneOS's [hardware security requirements](https://grapheneos.org/faq#future-devices). | ||||
|  | ||||
|     GrapheneOS's "extended support" devices do not have full security patches (firmware updates) due to the original equipment manufacturer (OEM) discontinuing support. These devices cannot be considered completely secure. | ||||
|  | ||||
| ### CalyxOS | ||||
|  | ||||
| !!! recommendation | ||||
|  | ||||
|     { align=right } | ||||
|  | ||||
|     **CalyxOS** is a decent alternative to GrapheneOS. | ||||
|  | ||||
|     It has some privacy features on top of AOSP, including [Datura firewall](https://calyxos.org/docs/tech/datura-details), [Signal](https://signal.org) integration in the dialer app, and a built in panic button. CalyxOS also comes with firmware updates and signed builds, so [verified boot](https://source.android.com/security/verifiedboot) is fully supported. | ||||
|  | ||||
|     To accomodate users who need Google Play Services, CalyxOS optionally includes [MicroG](https://microg.org/). With MicroG, CalyxOS also bundles in the [Mozilla](https://location.services.mozilla.com/) and [DejaVu](https://github.com/n76/DejaVu) location services. | ||||
|  | ||||
|     Currently, CalyxOS only supports [Pixel phones](https://calyxos.org/docs/guide/device-support/). | ||||
|  | ||||
|     [Visit calyxos.org](https://calyxos.org/){ .md-button .md-button--primary } [Privacy Policy](https://calyxinstitute.org/legal/privacy-policy){ .md-button } | ||||
|  | ||||
| !!! attention | ||||
|  | ||||
|     CalyxOS's "extended support" does not have full security patches due to the original equipment manufacturer (OEM) discontinuing support; therefore, they cannot be considered completely secure. | ||||
| [Why we recommend GrapheneOS over CalyxOS :material-arrow-right-drop-circle:](https://blog.privacyguides.org/2022/04/21/grapheneos-or-calyxos){ .md-button } | ||||
|  | ||||
| ### DivestOS | ||||
|  | ||||
| !!! recommendation | ||||
| <div class="admonition recommendation" markdown> | ||||
|  | ||||
|     { align=right } | ||||
| { align=right } | ||||
|  | ||||
|     **DivestOS** is a [soft-fork](https://en.wikipedia.org/wiki/Fork_(software_development)#Forking_of_free_and_open-source_software) of [LineageOS](https://lineageos.org/). | ||||
|     DivestOS inherits many [supported devices](https://divestos.org/index.php?page=devices&base=LineageOS) from LineageOS. It has signed builds, making it possible to have [verified boot](https://source.android.com/security/verifiedboot) on some non-Pixel devices. | ||||
| **DivestOS** is a soft-fork of [LineageOS](https://lineageos.org). | ||||
| DivestOS inherits many [supported devices](https://divestos.org/index.php?page=devices&base=LineageOS) from LineageOS. It has signed builds, making it possible to have [verified boot](https://source.android.com/security/verifiedboot) on some non-Pixel devices. | ||||
|  | ||||
|     [Visit divestos.org](https://divestos.org){ .md-button .md-button--primary } [Privacy Policy](https://divestos.org/index.php?page=privacy_policy){ .md-button } | ||||
| [:octicons-home-16: Homepage](https://divestos.org){ .md-button .md-button--primary } | ||||
| [:simple-torbrowser:](http://divestoseb5nncsydt7zzf5hrfg44md4bxqjs5ifcv4t7gt7u6ohjyyd.onion){ .card-link title="Onion Service" } | ||||
| [:octicons-eye-16:](https://divestos.org/index.php?page=privacy_policy){ .card-link title="Privacy Policy" } | ||||
| [:octicons-info-16:](https://divestos.org/index.php?page=faq){ .card-link title=Documentation} | ||||
| [:octicons-code-16:](https://github.com/divested-mobile){ .card-link title="Source Code" } | ||||
| [:octicons-heart-16:](https://divested.dev/pages/donate){ .card-link title=Contribute } | ||||
|  | ||||
| DivestOS has automated kernel vulnerability ([CVE](https://en.wikipedia.org/wiki/Common_Vulnerabilities_and_Exposures)) [patching](https://gitlab.com/divested-mobile/cve_checker), fewer proprietary blobs, a custom [hosts](https://divested.dev/index.php?page=dnsbl) file, and [F-Droid](https://www.f-droid.org) as the app store. It includes [UnifiedNlp](https://github.com/microg/UnifiedNlp) for network location and some hardening with [Mulch Webview](https://gitlab.com/divested-mobile/mulch). Users can also select the [Bromite SystemWebView](https://www.bromite.org/system_web_view) in ⚙️ Settings → Developer options → Webview implementation. DivestOS also includes kernel patches from GrapheneOS and enables security features in [defconfig](https://github.com/Divested-Mobile/DivestOS-Build/blob/master/Scripts/Common/Functions.sh#L698). | ||||
| </div> | ||||
|  | ||||
| DivestOS 16.0, 17.1, and 18.1 implements GrapheneOS's [`INTERNET`](https://developer.android.com/training/basics/network-ops/connecting) permission toggle and [hardened memory allocator](https://github.com/GrapheneOS/hardened_malloc). | ||||
| DivestOS has automated kernel vulnerability ([CVE](https://en.wikipedia.org/wiki/Common_Vulnerabilities_and_Exposures)) [patching](https://gitlab.com/divested-mobile/cve_checker), fewer proprietary blobs, and a custom [hosts](https://divested.dev/index.php?page=dnsbl) file. Its hardened WebView, [Mulch](https://gitlab.com/divested-mobile/mulch), enables [CFI](https://en.wikipedia.org/wiki/Control-flow_integrity) for all architectures and [network state partitioning](https://developer.mozilla.org/docs/Web/Privacy/State_Partitioning), and receives out-of-band updates. | ||||
| DivestOS also includes kernel patches from GrapheneOS and enables all available kernel security features via [defconfig hardening](https://github.com/Divested-Mobile/DivestOS-Build/blob/master/Scripts/Common/Functions.sh#L758). All kernels newer than version 3.4 include full page [sanitization](https://lwn.net/Articles/334747) and all ~22 Clang-compiled kernels have [`-ftrivial-auto-var-init=zero`](https://reviews.llvm.org/D54604?id=174471) enabled. | ||||
|  | ||||
| !!! attention | ||||
| DivestOS implements some system hardening patches originally developed for GrapheneOS. DivestOS 16.0 and higher implements GrapheneOS's [`INTERNET`](https://developer.android.com/training/basics/network-ops/connecting) and SENSORS permission toggle, [hardened memory allocator](https://github.com/GrapheneOS/hardened_malloc), [exec-spawning](https://blog.privacyguides.org/2022/04/21/grapheneos-or-calyxos/#additional-hardening), [JNI](https://en.wikipedia.org/wiki/Java_Native_Interface) [constification](https://en.wikipedia.org/wiki/Const_(computer_programming)), and partial [bionic](https://en.wikipedia.org/wiki/Bionic_(software)) hardening patchsets. 17.1 and higher features GrapheneOS's per-network full [MAC randomization](https://en.wikipedia.org/wiki/MAC_address#Randomization) option, [`ptrace_scope`](https://kernel.org/doc/html/latest/admin-guide/LSM/Yama.html) control, and automatic reboot/Wi-Fi/Bluetooth [timeout options](https://grapheneos.org/features). | ||||
|  | ||||
|     DivestOS firmware update [status](https://gitlab.com/divested-mobile/firmware-empty/-/blob/master/STATUS) varies across the devices it supports. For Pixel phones, we still recommend using GrapheneOS or CalyxOS. For other supported devices, DivestOS is a good alternative. | ||||
| DivestOS uses F-Droid as its default app store. We normally [recommend avoiding F-Droid](#f-droid), but doing so on DivestOS isn't viable; the developers update their apps via their own F-Droid repositories ([DivestOS Official](https://divestos.org/fdroid/official/?fingerprint=E4BE8D6ABFA4D9D4FEEF03CDDA7FF62A73FD64B75566F6DD4E5E577550BE8467) and [DivestOS WebView](https://divestos.org/fdroid/webview/?fingerprint=FB426DA1750A53D7724C8A582B4D34174E64A84B38940E5D5A802E1DFF9A40D2)). We recommend disabling the official F-Droid app and using [F-Droid Basic](https://f-droid.org/en/packages/org.fdroid.basic) **with the DivestOS repositories enabled** to keep those components up to date. For other apps, our recommended methods of obtaining them still apply. | ||||
|  | ||||
|     Not all of the supported devices have [verified boot](https://source.android.com/security/verifiedboot), and some perform it better than others. | ||||
| <div class="admonition warning" markdown> | ||||
| <p class="admonition-title">Warning</p> | ||||
|  | ||||
| ## Android security and privacy features | ||||
| ### User Profiles | ||||
| Multiple user profiles (Settings → System → Multiple users) are the simplest way to isolate in Android. With user profiles you can limit a user from making calls, SMS or installing apps on the device. Each profile is encrypted using its own encryption key and cannot access the data of any other profiles. Even the device owner cannot view the data of other profiles without knowing their password. Multiple user profiles is a more secure method of isolation. | ||||
| DivestOS firmware update [status](https://gitlab.com/divested-mobile/firmware-empty/-/blob/master/STATUS) and quality control varies across the devices it supports. We still recommend GrapheneOS depending on your device's compatibility. For other devices, DivestOS is a good alternative. | ||||
|  | ||||
| ### Work Profile | ||||
| [Work Profiles](https://support.google.com/work/android/answer/6191949) are another way to isolate individual apps and may be more convenient than separate user profiles. | ||||
| Not all of the supported devices have verified boot, and some perform it better than others. | ||||
|  | ||||
| A **device controller** such as [Shelter](#recommended-apps) is required, unless you're using CalyxOS which includes one. | ||||
| </div> | ||||
|  | ||||
| The work profile is dependent on a device controller to function. Features such as *File Shuttle* and *contact search blocking* or any kind of isolation features must be implemented by the controller. The user must also fully trust the device controller app, as it has full access to the data inside of the work profile. | ||||
| ## Android Devices | ||||
|  | ||||
| This method is generally less secure than a secondary user profile; however, it does allow you the convenience of running apps in both the work and personal profiles simultaneously. | ||||
| When purchasing a device, we recommend getting one as new as possible. The software and firmware of mobile devices are only supported for a limited time, so buying new extends that lifespan as much as possible. | ||||
|  | ||||
| ### Verified Boot | ||||
| [Verified Boot](https://source.android.com/security/verifiedboot) is an important part of the Android security model. It provides protection against [evil maid](https://en.wikipedia.org/wiki/Evil_maid_attack) attacks, malware persistence, and ensures security updates cannot be downgraded with [rollback protection](https://source.android.com/security/verifiedboot/verified-boot#rollback-protection). | ||||
| Avoid buying phones from mobile network operators. These often have a **locked bootloader** and do not support [OEM unlocking](https://source.android.com/devices/bootloader/locking_unlocking). These phone variants will prevent you from installing any kind of alternative Android distribution. | ||||
|  | ||||
| Android 10 and above has moved away from full-disk encryption (FDE) to more flexible [file-based encryption](https://source.android.com/security/encryption/file-based). | ||||
| Be very **careful** about buying second hand phones from online marketplaces. Always check the reputation of the seller. If the device is stolen, there's a possibility of it being entered in the [IMEI database](https://gsma.com/get-involved/working-groups/terminal-steering-group/imei-database). There is also a risk involved with you being associated with the activity of the previous owner. | ||||
|  | ||||
| Each user's data is encrypted using their own unique encryption key, and the operating system files are left unencrypted. Verified Boot ensures the integrity of the operating system files preventing an adversary with physical access from tampering or installing malware on the device. In the unlikely case that malware is able to exploit other parts of the system and gain higher privileged access, Verified Boot will prevent and revert changes to the system partition upon reboot of the device. | ||||
| A few more tips regarding Android devices and operating system compatibility: | ||||
|  | ||||
| Unfortunately, original equipment manufacturers (OEMs) are only obliged to support Verified Boot on their stock Android distribution. Only a few OEMs such as Google support custom Android Verified Boot (AVB) key enrollment on their devices. Some AOSP derivatives such as LineageOS or /e/ OS do not support Verified Boot even on hardware with Verified Boot support for third party operating systems. We recommend that you check for support **before** purchasing a new device. AOSP derivatives which do not support Verified Boot are **not** recommended. | ||||
| - Do not buy devices that have reached or are near their end-of-life, additional firmware updates must be provided by the manufacturer. | ||||
| - Do not buy preloaded LineageOS or /e/ OS phones or any Android phones without proper [Verified Boot](https://source.android.com/security/verifiedboot) support and firmware updates. These devices also have no way for you to check whether they've been tampered with. | ||||
| - In short, if a device or Android distribution is not listed here, there is probably a good reason. Check out our [forum](https://discuss.privacyguides.net) to find details! | ||||
|  | ||||
| ### VPN Killswitch | ||||
| Android 7 and above supports a VPN killswitch and it is available without the need to install third party apps. This feature can prevent leaks if the VPN is disconnected. It can be found in ⚙️ Settings → Network & internet → VPN → ⚙️ → Block connections without VPN. | ||||
| ### Google Pixel | ||||
|  | ||||
| ### Global Toggles | ||||
| Modern Android devices have global toggles for disabling [Bluetooth](https://en.wikipedia.org/wiki/Bluetooth) and location services. Android 12 introduced toggles for the camera and microphone. When not in use, we recommend disabling these features. Apps cannot use disabled features (even if granted individual permission) until re-enabled. | ||||
| Google Pixel phones are the **only** devices we recommend for purchase. Pixel phones have stronger hardware security than any other Android devices currently on the market, due to proper AVB support for third-party operating systems and Google's custom [Titan](https://security.googleblog.com/2021/10/pixel-6-setting-new-standard-for-mobile.html) security chips acting as the Secure Element. | ||||
|  | ||||
| ## Recommended Apps | ||||
| <div class="admonition recommendation" markdown> | ||||
|  | ||||
| ### Orbot | ||||
| { align=right } | ||||
|  | ||||
| !!! recommendation | ||||
| **Google Pixel** devices are known to have good security and properly support [Verified Boot](https://source.android.com/security/verifiedboot), even when installing custom operating systems. | ||||
|  | ||||
|     { align=right } | ||||
| Beginning with the **Pixel 8** and **8 Pro**, Pixel devices receive a minimum of 7 years of guaranteed security updates, ensuring a much longer lifespan compared to the 2-5 years competing OEMs typically offer. | ||||
|  | ||||
|     **Orbot** is a free proxy app that routes your connections through the Tor Network. | ||||
| [:material-shopping: Store](https://store.google.com/category/phones){ .md-button .md-button--primary } | ||||
|  | ||||
|     [Visit orbot.app](https://orbot.app/){ .md-button .md-button--primary } | ||||
| </div> | ||||
|  | ||||
|     **Downloads** | ||||
|     - [:fontawesome-brands-google-play: Google Play](https://play.google.com/store/apps/details?id=org.torproject.android) | ||||
|     - [:pg-f-droid: F-Droid](https://guardianproject.info/fdroid) | ||||
|     - [:fontawesome-brands-github: GitHub](https://github.com/guardianproject/orbot) | ||||
|     - [:fontawesome-brands-gitlab: GitLab](https://gitlab.com/guardianproject/orbot) | ||||
| Secure Elements like the Titan M2 are more limited than the processor's Trusted Execution Environment used by most other phones as they are only used for secrets storage, hardware attestation, and rate limiting, not for running "trusted" programs. Phones without a Secure Element have to use the TEE for *all* of those functions, resulting in a larger attack surface. | ||||
|  | ||||
| Orbot can proxy individual apps if they support SOCKS or HTTP proxying. It can also proxy all your network connections using [VpnService](https://developer.android.com/reference/android/net/VpnService) and can be used with the VPN killswitch (⚙️ Settings → Network & internet → VPN → ⚙️ → Block connections without VPN). | ||||
| Google Pixel phones use a TEE OS called Trusty which is [open source](https://source.android.com/security/trusty#whyTrusty), unlike many other phones. | ||||
|  | ||||
| For resistance against traffic analysis attacks, consider enabling *Isolate Destination Address* ( ⁝ →Settings → Connectivity). This will use a completely different Tor Circuit (different middle relay and exit nodes) for every domain you connect to. | ||||
| The installation of GrapheneOS on a Pixel phone is easy with their [web installer](https://grapheneos.org/install/web). If you don't feel comfortable doing it yourself and are willing to spend a bit of extra money, check out the [NitroPhone](https://shop.nitrokey.com/shop) as they come preloaded with GrapheneOS from the reputable [Nitrokey](https://nitrokey.com/about) company. | ||||
|  | ||||
| !!! attention | ||||
| A few more tips for purchasing a Google Pixel: | ||||
|  | ||||
|     Orbot is often outdated on the Guardian Project's [F-Droid repository](https://guardianproject.info/fdroid) and [Google Play](https://play.google.com/store/apps/details?id=org.torproject.android) so consider downloading directly from the [GitHub repository](https://github.com/guardianproject/orbot) instead. | ||||
| - If you're after a bargain on a Pixel device, we suggest buying an "**a**" model, just after the next flagship is released. Discounts are usually available because Google will be trying to clear their stock. | ||||
| - Consider price beating options and specials offered at physical stores. | ||||
| - Look at online community bargain sites in your country. These can alert you to good sales. | ||||
| - Google provides a list showing the [support cycle](https://support.google.com/nexus/answer/4457705) for each one of their devices. The price per day for a device can be calculated as: | ||||
|     <math xmlns="http://www.w3.org/1998/Math/MathML" display="inline" class="tml-display" style="display:inline math;"> | ||||
|       <mfrac> | ||||
|         <mtext>Cost</mtext> | ||||
|         <mrow> | ||||
|           <mtext>End of Life Date</mtext> | ||||
|           <mo>−</mo> | ||||
|           <mtext>Current Date</mtext> | ||||
|         </mrow> | ||||
|       </mfrac> | ||||
|     </math> | ||||
|     , meaning that the longer use of the device the lower cost per day. | ||||
| - If the Pixel is unavailable in your region, the [NitroPhone](https://shop.nitrokey.com/shop) can be shipped globally. | ||||
|  | ||||
|     All versions are signed using the same signature so they should be compatible with each other. | ||||
| ## General Apps | ||||
|  | ||||
| We recommend a wide variety of Android apps throughout this site. The apps listed here are Android-exclusive and specifically enhance or replace key system functionality. | ||||
|  | ||||
| ### Shelter | ||||
|  | ||||
| !!! recommendation | ||||
| <div class="admonition recommendation" markdown> | ||||
|  | ||||
|     { align=right } | ||||
| { align=right } | ||||
|  | ||||
|     **Shelter** is an app that helps you leverage the Android work profile to isolate other apps. | ||||
| **Shelter** is an app that helps you leverage Android's Work Profile functionality to isolate or duplicate apps on your device. | ||||
|  | ||||
|     Shelter supports blocking contact search cross profiles and sharing files across profiles via the default file manager ([DocumentsUI](https://source.android.com/devices/architecture/modular-system/documentsui)). | ||||
| Shelter supports blocking contact search cross profiles and sharing files across profiles via the default file manager ([DocumentsUI](https://source.android.com/devices/architecture/modular-system/documentsui)). | ||||
|  | ||||
|     [Visit gitea.angry.im](https://gitea.angry.im/PeterCxy/Shelter){ .md-button .md-button--primary } | ||||
| [:octicons-repo-16: Repository](https://gitea.angry.im/PeterCxy/Shelter#shelter){ .md-button .md-button--primary } | ||||
| [:octicons-code-16:](https://gitea.angry.im/PeterCxy/Shelter){ .card-link title="Source Code" } | ||||
| [:octicons-heart-16:](https://patreon.com/PeterCxy){ .card-link title=Contribute } | ||||
|  | ||||
|     **Downloads:** | ||||
|     - [:fontawesome-brands-google-play: Google Play](https://play.google.com/store/apps/details?id=net.typeblog.shelter) | ||||
|     - [:pg-f-droid: F-Droid](https://f-droid.org/en/packages/net.typeblog.shelter) | ||||
|     - [:fontawesome-brands-github: GitHub](https://github.com/PeterCxy/Shelter) | ||||
|     - [:fontawesome-brands-git-alt: Source](https://gitea.angry.im/PeterCxy/Shelter) | ||||
| </div> | ||||
|  | ||||
| !!! attention | ||||
| <div class="admonition warning" markdown> | ||||
| <p class="admonition-title">Warning</p> | ||||
|  | ||||
|     As CalyxOS includes a device controller, we recommend using their built in work profile instead. | ||||
| Shelter is recommended over [Insular](https://secure-system.gitlab.io/Insular) and [Island](https://github.com/oasisfeng/island) as it supports [contact search blocking](https://secure-system.gitlab.io/Insular/faq.html). | ||||
|  | ||||
|     Shelter is recommended over [Insular](https://secure-system.gitlab.io/Insular/) and [Island](https://github.com/oasisfeng/island) as it supports [contact search blocking](https://secure-system.gitlab.io/Insular/faq.html). | ||||
| When using Shelter, you are placing complete trust in its developer, as Shelter acts as a [Device Admin](https://developer.android.com/guide/topics/admin/device-admin) to create the Work Profile, and it has extensive access to the data stored within the Work Profile. | ||||
|  | ||||
|     When using Shelter, you are placing complete trust in its developer as Shelter would be acting as a [Device Admin](https://developer.android.com/guide/topics/admin/device-admin) for the work profile and has extensive access to the data stored within it. | ||||
|  | ||||
|  | ||||
| ### Auditor | ||||
|  | ||||
| !!! recommendation | ||||
|  | ||||
|     { align=right } | ||||
|     { align=right } | ||||
|  | ||||
|     **Auditor** is an app which leverages hardware security features to provide device integrity monitoring for [supported devices](https://attestation.app/about#device-support). Currently it works with GrapheneOS and the device's stock operating system. | ||||
|  | ||||
|     [Visit attestation.app](https://attestation.app){ .md-button .md-button--primary } | ||||
|  | ||||
|     **Downloads:** | ||||
|     - [:fontawesome-brands-google-play: Google Play](https://play.google.com/store/apps/details?id=app.attestation.auditor) | ||||
|     - [:fontawesome-brands-github: GitHub](https://github.com/GrapheneOS/Auditor) | ||||
|  | ||||
| Auditor performs attestation and intrusion detection by: | ||||
|  | ||||
|  - Using a [Trust On First Use (TOFU)](https://en.wikipedia.org/wiki/Trust_on_first_use) model between an *auditor* and *auditee*, the pair establish a private key in the [hardware-backed keystore](https://source.android.com/security/keystore/) of the *Auditor*. | ||||
|  - The *auditor* can either be another instance of the Auditor app or the [Remote Attestation Service](https://attestation.app). | ||||
|  - The *auditor* records the current state and configuration of the *auditee*. | ||||
|  - Should tampering with the operating system of the *auditee* after the pairing is complete, the auditor will be aware of the change in the device state and configurations. | ||||
|  - The user will be alerted to the change. | ||||
|  | ||||
| No personally identifiable information is submitted to the attestation service. We recommend that you sign up with an anonymous account and enable remote attestation for continuous monitoring. | ||||
|  | ||||
| If your [threat model](/threat-modeling/) requires privacy you could consider using Orbot or a VPN to hide your IP address from the attestation service. | ||||
| To make sure that your hardware and operating system is genuine, [perform local attestation](https://grapheneos.org/install/web#verifying-installation) immediately after the device has been installed and prior to any internet connection. | ||||
| </div> | ||||
|  | ||||
| ### Secure Camera | ||||
|  | ||||
| !!! recommendation | ||||
| <div class="admonition recommendation" markdown> | ||||
|  | ||||
|     { align=right } | ||||
|     { align=right } | ||||
| { align=right } | ||||
| { align=right } | ||||
|  | ||||
|       **Secure Camera** is an camera app focused on privacy and security which can capture images, videos, and QR codes. CameraX vendor extensions (Portrait, HDR, Night Sight, Face Retouch, and Auto) are also supported on available devices. | ||||
| **Secure Camera** is a camera app focused on privacy and security which can capture images, videos and QR codes. CameraX vendor extensions (Portrait, HDR, Night Sight, Face Retouch, and Auto) are also supported on available devices. | ||||
|  | ||||
|     [Visit github.com](https://github.com/GrapheneOS/Camera){ .md-button .md-button--primary } | ||||
| [:octicons-repo-16: Repository](https://github.com/GrapheneOS/Camera){ .md-button .md-button--primary } | ||||
| [:octicons-info-16:](https://grapheneos.org/usage#camera){ .card-link title=Documentation} | ||||
| [:octicons-code-16:](https://github.com/GrapheneOS/Camera){ .card-link title="Source Code" } | ||||
| [:octicons-heart-16:](https://grapheneos.org/donate){ .card-link title=Contribute } | ||||
|  | ||||
|     **Downloads:** | ||||
|     - [:fontawesome-brands-google-play: Google Play](https://play.google.com/store/apps/details?id=app.grapheneos.camera.play) | ||||
|     - [:fontawesome-brands-github: GitHub](https://github.com/GrapheneOS/Camera/releases) | ||||
| <details class="downloads" markdown> | ||||
| <summary>Downloads</summary> | ||||
|  | ||||
| - [:simple-googleplay: Google Play](https://play.google.com/store/apps/details?id=app.grapheneos.camera.play) | ||||
| - [:simple-github: GitHub](https://github.com/GrapheneOS/Camera/releases) | ||||
| - [:material-cube-outline: GrapheneOS App Store](https://github.com/GrapheneOS/Apps/releases) | ||||
|  | ||||
| </details> | ||||
|  | ||||
| </div> | ||||
|  | ||||
| Main privacy features include: | ||||
|  | ||||
| @@ -202,189 +276,188 @@ Main privacy features include: | ||||
| - Use of the new [Media](https://developer.android.com/training/data-storage/shared/media) API, therefore [storage permissions](https://developer.android.com/training/data-storage) are not required | ||||
| - Microphone permission not required unless you want to record sound | ||||
|  | ||||
| !!! note | ||||
| <div class="admonition note" markdown> | ||||
| <p class="admonition-title">Note</p> | ||||
|  | ||||
|     Metadata is not currently deleted from video files but that is planned. | ||||
| Metadata is not currently deleted from video files but that is planned. | ||||
|  | ||||
|     The image orientation metadata is not deleted. If you enable location (in Secure Camera) that **won't** be deleted either. If you want to delete that later you will need to use an external app such as [Scrambled Exif](https://gitlab.com/juanitobananas/scrambled-exif/). | ||||
| The image orientation metadata is not deleted. If you enable location (in Secure Camera) that **won't** be deleted either. If you want to delete that later you will need to use an external app such as [ExifEraser](data-redaction.md#exiferaser-android). | ||||
|  | ||||
| </div> | ||||
|  | ||||
| ### Secure PDF Viewer | ||||
|  | ||||
| !!! recommendation | ||||
| <div class="admonition recommendation" markdown> | ||||
|  | ||||
|     { align=right } | ||||
|     { align=right } | ||||
| { align=right } | ||||
| { align=right } | ||||
|  | ||||
|     **Secure PDF Viewer** is a PDF viewer based on [pdf.js](https://en.wikipedia.org/wiki/PDF.js) that doesn't require any permissions. The PDF is fed into a [sandboxed](https://en.wikipedia.org/wiki/Sandbox_(software_development)) [webview](https://developer.android.com/guide/webapps/webview). This means that it doesn't require permission directly to access content or files. | ||||
| **Secure PDF Viewer** is a PDF viewer based on [pdf.js](https://en.wikipedia.org/wiki/PDF.js) that doesn't require any permissions. The PDF is fed into a [sandboxed](https://en.wikipedia.org/wiki/Sandbox_(software_development)) [webview](https://developer.android.com/guide/webapps/webview). This means that it doesn't require permission directly to access content or files. | ||||
|  | ||||
|     [Content-Security-Policy](https://en.wikipedia.org/wiki/Content_Security_Policy) is used to enforce that the JavaScript and styling properties within the WebView are entirely static content. | ||||
| [Content-Security-Policy](https://en.wikipedia.org/wiki/Content_Security_Policy) is used to enforce that the JavaScript and styling properties within the WebView are entirely static content. | ||||
|  | ||||
|     [Visit github.com](https://github.com/GrapheneOS/PdfViewer){ .md-button .md-button--primary } | ||||
| [:octicons-repo-16: Repository](https://github.com/GrapheneOS/PdfViewer){ .md-button .md-button--primary } | ||||
| [:octicons-code-16:](https://github.com/GrapheneOS/PdfViewer){ .card-link title="Source Code" } | ||||
| [:octicons-heart-16:](https://grapheneos.org/donate){ .card-link title=Contribute } | ||||
|  | ||||
|     **Downloads:** | ||||
|     - [:fontawesome-brands-google-play: Google Play](https://play.google.com/store/apps/details?id=app.grapheneos.pdfviewer.play) | ||||
|     - [:fontawesome-brands-github: GitHub](https://github.com/GrapheneOS/PdfViewer/releases) | ||||
| <details class="downloads" markdown> | ||||
| <summary>Downloads</summary> | ||||
|  | ||||
| ### PrivacyBlur | ||||
| - [:simple-googleplay: Google Play](https://play.google.com/store/apps/details?id=app.grapheneos.pdfviewer.play) | ||||
| - [:simple-github: GitHub](https://github.com/GrapheneOS/PdfViewer/releases) | ||||
| - [:material-cube-outline: GrapheneOS App Store](https://github.com/GrapheneOS/Apps/releases) | ||||
|  | ||||
| !!! recommendation | ||||
| </details> | ||||
|  | ||||
|     { align=right } | ||||
| </div> | ||||
|  | ||||
|     **PrivacyBlur** is a free app which can blur sensitive portions of pictures before sharing them online. | ||||
| ## Obtaining Applications | ||||
|  | ||||
|     [Visit privacyblur.app](https://privacyblur.app/){ .md-button .md-button--primary } | ||||
| ### Obtainium | ||||
|  | ||||
|     **Downloads:** | ||||
|     - [:fontawesome-brands-google-play: Google Play](https://play.google.com/store/apps/details?id=de.mathema.privacyblur) | ||||
|     - [:pg-f-droid: F-Droid](https://f-droid.org/en/packages/de.mathema.privacyblur/) | ||||
|     - [:fontawesome-brands-github: GitHub](https://github.com/MATHEMA-GmbH/privacyblur) | ||||
| <div class="admonition recommendation" markdown> | ||||
|  | ||||
| !!! warning | ||||
| { align=right } | ||||
|  | ||||
|     You should **never** use blur to redact [text in images](https://bishopfox.com/blog/unredacter-tool-never-pixelation). If you want to redact text in an image, draw a box over the text. For this we suggest [Pocket Paint](https://github.com/Catrobat/Paintroid) or [Imagepipe](https://codeberg.org/Starfish/Imagepipe). | ||||
| **Obtainium** is an app manager which allows you to install and update apps directly from the developer's own releases page (i.e. GitHub, GitLab, the developer's website, etc.), rather than a centralized app store/repository. It supports automatic background updates on Android 12 and higher. | ||||
|  | ||||
| [:octicons-repo-16: Repository](https://github.com/ImranR98/Obtainium#readme){ .md-button .md-button--primary } | ||||
| [:octicons-info-16:](https://github.com/ImranR98/Obtainium/wiki){ .card-link title=Documentation} | ||||
| [:octicons-code-16:](https://github.com/ImranR98/Obtainium){ .card-link title="Source Code" } | ||||
| [:octicons-heart-16:](https://github.com/sponsors/ImranR98){ .card-link title=Contribute } | ||||
|  | ||||
| ## General Recommendations | ||||
| ### Avoid Root | ||||
| [Rooting](https://en.wikipedia.org/wiki/Rooting_(Android)) Android phones can decrease security significantly as it weakens the complete [Android security model](https://en.wikipedia.org/wiki/Android_(operating_system)#Security_and_privacy). This can decrease privacy should there be an exploit that is assisted by the decreased security. Common rooting methods involve directly tampering with the boot partition, making it impossible to perform successful [Verified Boot](https://source.android.com/security/verifiedboot). Apps that require root will also modify the system partition meaning that Verified Boot would have to remain disabled. Having root exposed directly in the user interface also increases the [attack surface](https://en.wikipedia.org/wiki/Attack_surface) of your device and may assist in [privilege escalation](https://en.wikipedia.org/wiki/Privilege_escalation) vulnerabilities and [SELinux](https://en.wikipedia.org/wiki/Security-Enhanced_Linux) policy bypasses. | ||||
| <details class="downloads" markdown> | ||||
| <summary>Downloads</summary> | ||||
|  | ||||
| Adblockers (AdAway) which modify the [hosts file](https://en.wikipedia.org/wiki/Hosts_(file)) and firewalls (AFWall+) which require root access persistently are dangerous and should not be used. They are also not the correct way to solve their intended purposes. For Adblocking we suggest encrypted [DNS](/dns) or [VPN](/providers/vpn/) server blocking solutions instead. RethinkDNS, TrackerControl and AdAway in non-root mode will take up the VPN slot (by using a local loopback VPN) preventing you from using privacy enhancing services such as Orbot or a real VPN server. | ||||
| - [:simple-github: GitHub](https://github.com/ImranR98/Obtainium/releases) | ||||
|  | ||||
| AFWall+ works based on the [packet filtering](https://en.wikipedia.org/wiki/Firewall_(computing)#Packet_filter) approach and may be bypassable in some situations. | ||||
| </details> | ||||
|  | ||||
| We do not believe that the security sacrifices made by rooting a phone are worth the questionable privacy benefits of those apps. | ||||
| </div> | ||||
|  | ||||
| ### Firmware Updates | ||||
| Firmware updates are critical for maintaining security and without them your device cannot be secure. Original equipment manufacturers (OEMs)—in other words, phone manufacturers—have support agreements with their partners to provide the closed source components for a limited support period. These are detailed in the monthly [Android Security Bulletins](https://source.android.com/security/bulletin). | ||||
| Obtainium allows you to download APK installer files from a wide variety of sources, and it is up to you to ensure those sources and apps are legitimate. For example, using Obtainium to install Signal from [Signal's APK landing page](https://signal.org/android/apk) should be fine, but installing from third-party APK repositories like Aptoide or APKPure may pose additional risks. The risk of installing a malicious *update* is lower, because Android itself verifies that all app updates are signed by the same developer as the existing app on your phone before installing them. | ||||
|  | ||||
| As the components of the phone such as the processor and radio technologies rely on closed source components, the updates must be provided by the respective manufacturers. Therefore it is important that you purchase a device within an active support cycle. [Qualcomm](https://www.qualcomm.com/news/releases/2020/12/16/qualcomm-and-google-announce-collaboration-extend-android-os-support-and) and [Samsung](https://news.samsung.com/us/samsung-galaxy-security-extending-updates-knox/) support their devices for 4 years while cheaper products often have shorter support. With the introduction of the [Pixel 6](https://support.google.com/pixelphone/answer/4457705), Google now makes their own system on chip (SoC) and they will provide 5 years of support. | ||||
| ### GrapheneOS App Store | ||||
|  | ||||
| Devices that have reached their end-of-life (EoL) and are no longer supported by the SoC manufacturer, cannot receive firmware updates from OEM vendors or after market Android distributors. This means that security issues with those devices will remain unfixed. | ||||
| GrapheneOS's app store is available on [GitHub](https://github.com/GrapheneOS/Apps/releases). It supports Android 12 and above and is capable of updating itself. The app store has standalone applications built by the GrapheneOS project such as the [Auditor](https://attestation.app), [Camera](https://github.com/GrapheneOS/Camera), and [PDF Viewer](https://github.com/GrapheneOS/PdfViewer). If you are looking for these applications, we highly recommend that you get them from GrapheneOS's app store instead of the Play Store, as the apps on their store are signed by the GrapheneOS's project own signature that Google does not have access to. | ||||
|  | ||||
| ### Android Versions | ||||
| It's important to not use an [end-of-life](https://endoflife.date/android) version of Android. Newer versions of Android not only receive security updates for the operating system but also important privacy enhancing updates too. For example, [prior to Android 10](https://developer.android.com/about/versions/10/privacy/changes), any user apps with the [`READ_PHONE_STATE`](https://developer.android.com/reference/android/Manifest.permission#READ_PHONE_STATE) permission could access sensitive and unique serial numbers of your phone such as [IMEI](https://en.wikipedia.org/wiki/International_Mobile_Equipment_Identity), [MEID](https://en.wikipedia.org/wiki/Mobile_equipment_identifier), your SIM card's [IMSI](https://en.wikipedia.org/wiki/International_mobile_subscriber_identity), whereas now they must be system apps to do so. System apps are only provided by the OEM or Android distribution. | ||||
| ### Aurora Store | ||||
|  | ||||
| ### Android Permissions | ||||
| [Permissions on Android](https://developer.android.com/guide/topics/permissions/overview) grant users control over what apps are allowed to access. Google regularly makes [improvements](https://developer.android.com/about/versions/11/privacy/permissions) on the permission system in each successive version. All user installed apps are strictly [sandboxed](https://source.android.com/security/app-sandbox), therefore there is no need to install any antivirus apps. The savings you make from not purchasing or subscribing to security apps is better spent on paying for a supported device in the future. | ||||
| The Google Play Store requires a Google account to login which is not great for privacy. You can get around this by using an alternative client, such as Aurora Store. | ||||
|  | ||||
| Should you want to run an app that you're unsure about, consider using a user or work [profile](/android/#android-security-privacy). | ||||
| <div class="admonition recommendation" markdown> | ||||
|  | ||||
| ### Advanced Protection Program | ||||
| If you have a Google account we suggest enrolling in the [Advanced Protection Program](https://landing.google.com/advancedprotection/). It is available at no cost to anyone with two or more hardware security keys with [U2F](https://en.wikipedia.org/wiki/Universal_2nd_Factor) support. | ||||
| { align=right } | ||||
|  | ||||
| The Advanced Protection Program provides enhanced threat monitoring and enables: | ||||
| **Aurora Store** is a Google Play Store client which does not require a Google Account, Google Play Services, or microG to download apps. | ||||
|  | ||||
|  - Stricter two factor authentication; e.g. that [U2F](https://en.wikipedia.org/wiki/Universal_2nd_Factor) or [FIDO2](https://en.wikipedia.org/wiki/WebAuthn) **must** be used and disallows the use of [SMS OTPs](https://en.wikipedia.org/wiki/One-time_password#SMS), [TOTP](https://en.wikipedia.org/wiki/Time-based_one-time_password), and [OAuth](https://en.wikipedia.org/wiki/OAuth) | ||||
|  - Only Google and verified third party apps can access account data | ||||
|  - Scanning of incoming emails on Gmail accounts for [phishing](https://en.wikipedia.org/wiki/Phishing#Email_phishing) attempts | ||||
|  - Stricter [safe browser scanning](https://www.google.com/chrome/privacy/whitepaper.html#malware) with Google Chrome | ||||
|  - Stricter recovery process for accounts with lost credentials | ||||
| [:octicons-home-16: Homepage](https://auroraoss.com){ .md-button .md-button--primary } | ||||
| [:octicons-eye-16:](https://gitlab.com/AuroraOSS/AuroraStore/-/blob/master/POLICY.md){ .card-link title="Privacy Policy" } | ||||
| [:octicons-code-16:](https://gitlab.com/AuroraOSS/AuroraStore){ .card-link title="Source Code" } | ||||
|  | ||||
|  For users that are using the privileged Google Play Services (common on stock operating systems), the Advanced Protection Program also comes with [additional benefits](https://support.google.com/accounts/answer/9764949?hl=en) such as: | ||||
|  - Not allowing app installation outside of the Google Play Store, the OS vendor's app store, or via [`adb`](https://en.wikipedia.org/wiki/Android_Debug_Bridge) | ||||
|  - Mandatory automatic device scanning with [Play Protect](https://support.google.com/googleplay/answer/2812853?hl=en#zippy=%2Chow-malware-protection-works%2Chow-privacy-alerts-work) | ||||
|  - Warning the user about unverified applications | ||||
| <details class="downloads" markdown> | ||||
| <summary>Downloads</summary> | ||||
|  | ||||
| ### SafetyNet and Play Integrity API | ||||
| [SafetyNet](https://developer.android.com/training/safetynet/attestation) and the [Play Integrity APIs](https://developer.android.com/google/play/integrity) are generally used for [banking apps](https://grapheneos.org/usage#banking-apps). Many banking apps will work fine in GrapheneOS with sandboxed Play services, however some non-financal apps have their own crude anti-tampering mechanisms which might fail. GrapheneOS passes the `basicIntegrity` check, but not the certification check `ctsProfileMatch`. Devices with Android 8 or later have hardware attestation support which cannot be bypassed without leaked keys or serious vulnerabilities. | ||||
| - [:simple-gitlab: GitLab](https://gitlab.com/AuroraOSS/AuroraStore/-/releases) | ||||
|  | ||||
| As for Google Wallet, we don't recommend this due to their [privacy policy](https://payments.google.com/payments/apis-secure/get_legal_document?ldo=0&ldt=privacynotice&ldl=en), which states you must opt-out if you don't want your credit rating and personal information shared with affiliate marketing services. | ||||
| </details> | ||||
|  | ||||
| ### Advertising ID | ||||
| All devices with Google Play Services installed automatically generate an [advertising ID](https://support.google.com/googleplay/android-developer/answer/6048248?hl=en) used for targeted advertising. Disable this feature to limit the data collected about you. | ||||
| </div> | ||||
|  | ||||
| On Android distributions with [Sandboxed Google Play](https://grapheneos.org/usage#sandboxed-google-play), go to ⚙️ Settings → Apps → Sandboxed Google Play → Google Settings → Ads and select **Delete advertising ID**. | ||||
| Aurora Store does not allow you to download paid apps with their anonymous account feature. You can optionally log in with your Google account with Aurora Store to download apps you have purchased, which does give access to the list of apps you've installed to Google. However, you still benefit from not requiring the full Google Play client and Google Play Services or microG on your device. | ||||
|  | ||||
| On Android distributions with privileged Google Play Services (such as stock OSes), the setting may be in one of several locations. Check | ||||
|  - ⚙️ Settings → Google → Ads | ||||
|  - ⚙️ Settings → Privacy → Ads | ||||
| ### Manually with RSS Notifications | ||||
|  | ||||
| Depending on your system, you will either be given the option to delete your advertising ID or to "Opt out of interest-based ads". You should delete the advertising ID if you are given the option to, and if you are not, we recommend that you opt out of interested-based ads and then reset your advertising ID. | ||||
| For apps that are released on platforms like GitHub and GitLab, you may be able to add an RSS feed to your [news aggregator](news-aggregators.md) that will help you keep track of new releases. | ||||
|  | ||||
| ### Android Device Shopping | ||||
| Google Pixels are known to have good security and properly support [Verified Boot](https://source.android.com/security/verifiedboot). Some other phones such as the Fairphone and OnePlus devices also support custom Android Verified Boot (AVB) key enrollment. However, there have been issues with their older models. In the past they were using [test keys](https://social.coop/@dazinism/105346943304083054) or not doing proper verification, making Verified Boot on those devices useless. | ||||
|     | ||||
|  | ||||
| Avoid buying phones from mobile network operators. These often have a **locked bootloader** and do not support [OEM unlocking](https://source.android.com/devices/bootloader/locking_unlocking). These phone variants will prevent you from installing any kind of alternative Android distribution. Phones that cannot be unlocked will often have an [IMEI](https://en.wikipedia.org/wiki/International_Mobile_Equipment_Identity) starting with "35", that includes phones from purchased from Verizon, Telus, Rogers, EE, etc. | ||||
| #### GitHub | ||||
|  | ||||
| Be very **careful** about buying second hand phones from online marketplaces. Always check the reputation of the seller. If the device is stolen there's a possibility of [IMEI blacklisting](https://www.gsma.com/security/resources/imei-blacklisting/). There is also a risk involved with you being associated with the activity of the previous owner. | ||||
| On GitHub, using [Secure Camera](#secure-camera) as an example, you would navigate to its [releases page](https://github.com/GrapheneOS/Camera/releases) and append `.atom` to the URL: | ||||
|  | ||||
| We have these general tips: | ||||
|  - If you're after a bargain on a Pixel device, we suggest buying an "**a**" model, just after the next flagship is released. Discounts are usually available because Google will be trying to clear their stock. | ||||
|  - Consider price beating options and specials offered at [brick and mortar](https://en.wikipedia.org/wiki/Brick_and_mortar) stores. | ||||
|  - Look at online community bargain sites in your country. These can alert you to good sales. | ||||
|  - The price per day for a device can be calculated as  $\text {EoL Date}-\text{Current Date} \over \text{Cost}$. Google provides a [list](https://support.google.com/nexus/answer/4457705) of their supported devices. | ||||
|  - Do not buy devices that have reached or are near their end-of-life, additional firmware updates must be provided by the manufacturer. | ||||
|  - Do not buy preloaded LineageOS or /e/ OS phones or any Android phones without proper [Verified Boot](https://source.android.com/security/verifiedboot) support and firmware updates. These devices also have no way for you to check whether they've been tampered with. | ||||
|  - In short, if a device or Android distribution is not listed here, there is probably a good reason, so check our [discussions](https://github.com/privacyguides/privacyguides.org/discussions) page. | ||||
| `https://github.com/GrapheneOS/Camera/releases.atom` | ||||
|  | ||||
| The installation of GrapheneOS on a Pixel phone is easy with their [web installer](https://grapheneos.org/install/web). If you don't feel comfortable doing it yourself and are willing to spend a bit of extra money, check out the [NitroPhone](https://shop.nitrokey.com/shop) as they come preloaded with GrapheneOS from the reputable [Nitrokey](https://www.nitrokey.com/about) company. The GrapheneOS project is not currently affiliated with any vendor and cannot ensure the quality or security of their products. | ||||
| #### GitLab | ||||
|  | ||||
| A [CalyxOS membership](https://calyxinstitute.org/membership/calyxos) also entitles you to a device preloaded with CalyxOS. | ||||
| On GitLab, using [Aurora Store](#aurora-store) as an example, you would navigate to its [project repository](https://gitlab.com/AuroraOSS/AuroraStore) and append `/-/tags?format=atom` to the URL: | ||||
|  | ||||
| ## GrapheneOS's App Store | ||||
| GrapheneOS's app store is available on [GitHub](https://github.com/GrapheneOS/Apps/releases). It supports Android 12 and above and is capable of updating itself. The app store has standalone applications built by the GrapheneOS project such as the [Auditor](https://attestation.app/), [Camera](https://github.com/GrapheneOS/Camera), and [PDF Viewer](https://github.com/GrapheneOS/PdfViewer). If you are looking for these applications, we highly recommend that you get them from GrapheneOS's app store instead of the Play Store, as the apps on their store are signed by the GrapheneOS's project own signature that Google does not have access to. | ||||
| `https://gitlab.com/AuroraOSS/AuroraStore/-/tags?format=atom` | ||||
|  | ||||
| ## F-Droid | ||||
| F-Droid is often recommended as an alternative to Google Play, particularly in the privacy community. The option to add third party repositories and not be confined to Google's [walled garden](https://en.wikipedia.org/wiki/Closed_platform) has led to its popularity. F-Droid additionally has [reproducible builds](https://f-droid.org/en/docs/Reproducible_Builds/) for some applications, and is dedicated to free and open source software. However, there are problems with the official F-Droid client, their quality control, and how they build, sign and deliver packages, outlined in this [post](https://wonderfall.dev/fdroid-issues/). | ||||
| #### Verifying APK Fingerprints | ||||
|  | ||||
| ### Droid-ify | ||||
| If you download APK files to install manually, you can verify their signature with the [`apksigner`](https://developer.android.com/studio/command-line/apksigner) tool, which is a part of Android [build-tools](https://developer.android.com/studio/releases/build-tools). | ||||
|  | ||||
| The official F-Droid client targets a [low API level](https://wonderfall.dev/fdroid-issues/#3-low-target-api-level-sdk-for-client--apps) and does not utilize the [seamless updates](https://www.androidcentral.com/google-will-finally-bring-seamless-app-updates-alternative-app-stores-android-12) feature introduced in Android 12. Targeting lower API levels means that the F-Droid client cannot take advantage of the new improvements in the application sandboxes that comes with higher API levels. For automatic updates to work, the F-Droid client requires that the [Privileged Extension](https://f-droid.org/en/packages/org.fdroid.fdroid.privileged/) be included in the operating system, granting it more privileges than what a normal app would have, which is not great for security. | ||||
| 1. Install [Java JDK](https://oracle.com/java/technologies/downloads). | ||||
|  | ||||
| To mitigate these problems, we recommend [Droid-ify](https://github.com/Iamlooker/Droid-ify) as it supports seamless updates on Android 12 and above without needing any special privileges and targets a higher API level. | ||||
| 2. Download the [Android Studio command line tools](https://developer.android.com/studio#command-tools). | ||||
|  | ||||
| !!! recommendation | ||||
| 3. Extract the downloaded archive: | ||||
|  | ||||
|     { align=right } | ||||
|     ```bash | ||||
|     unzip commandlinetools-*.zip | ||||
|     cd cmdline-tools | ||||
|     ./bin/sdkmanager --sdk_root=./ "build-tools;29.0.3" | ||||
|     ``` | ||||
|  | ||||
|     **Droid-ify** is a modern F-Droid client made with MaterialUI, forked from [Foxy Droid](https://github.com/kitsunyan/foxy-droid). | ||||
| 4. Run the signature verification command: | ||||
|  | ||||
|     Unlike the official F-Droid client, Droid-ify supports seamless updates on Android 12 and above without the need for a privileged extension. If your Android distribution is on Android 12 or above and does not include the [F-Droid privileged extension](https://f-droid.org/en/packages/org.fdroid.fdroid.privileged/), it is highly recommended that you use Droid-ify instead of the official client. | ||||
|     ```bash | ||||
|     ./build-tools/29.0.3/apksigner verify --print-certs ../Camera-37.apk | ||||
|     ``` | ||||
|  | ||||
|     **Downloads:** | ||||
|     - [:fontawesome-brands-android: APK Download](https://android.izzysoft.de/repo/apk/com.looker.droidify) | ||||
|     - [:fontawesome-brands-github: GitHub](https://github.com/Iamlooker/Droid-ify) | ||||
| 5. The resulting hashes can then be compared with another source. Some developers such as Signal [show the fingerprints](https://signal.org/android/apk) on their website. | ||||
|  | ||||
| ### Where to get your applications | ||||
| Sometimes the official F-Droid repository may fall behind on updates. F-Droid maintainers reuse package IDs while signing apps with their own keys, which is not ideal as it does give the F-Droid team ultimate trust. The Google Play version of some apps may contain unwanted telemetry or lack features that are available in the F-Droid version. The Google Play Store requires a Google account to login which is not great for privacy. The [Aurora Store](https://auroraoss.com/download/AuroraStore/) (a Google Play Store proxy) does not always work, though it does most of the time. | ||||
|     ```bash | ||||
|     Signer #1 certificate DN: CN=GrapheneOS | ||||
|     Signer #1 certificate SHA-256 digest: 6436b155b917c2f9a9ed1d15c4993a5968ffabc94947c13f2aeee14b7b27ed59 | ||||
|     Signer #1 certificate SHA-1 digest: 23e108677a2e1b1d6e6b056f3bb951df7ad5570c | ||||
|     Signer #1 certificate MD5 digest: dbbcd0cac71bd6fa2102a0297c6e0dd3 | ||||
|     ``` | ||||
|  | ||||
| We have these general tips: | ||||
| ### F-Droid | ||||
|  | ||||
|  - Check if the app developers have their own F-Droid repository first, e.g. [Bitwarden](https://bitwarden.com/), [Samourai Wallet](https://www.samouraiwallet.com/), or [Newpipe](https://newpipe.net/), which have their own repositories with less telemetry, additional features or faster updates. This is the ideal situation and you should be using these repositories if possible. | ||||
|  - Check if an app is available on the [IzzyOnDroid](https://apt.izzysoft.de/fdroid/) repository. The IzzyOnDroid repository pulls builds directly from GitHub and is the next best thing to the developers' own repositories. We recommend that you download the GitHub builds and install them manually first, then use IzzyOnDroid for any subsequent updates. This will ensure that the signature of the applications you get from IzzyOnDroid matches that of the developer and the packages have not been tampered with. | ||||
|  - Check if there are any differences between the F-Droid version and the Google Play Store version. Some applications like [IVPN](https://www.ivpn.net/) do not include certain features (eg [AntiTracker](https://www.ivpn.net/knowledgebase/general/antitracker-faq/)) in their Google Play Store build out of fear of censorship by Google. | ||||
| { align=right width=120px } | ||||
|  | ||||
| Evaluate whether the additional features in the F-Droid build are worth the slower updates. Also think about whether faster updates from the Google Play Store are worth the potential privacy isues in your [threat model](/threat-modeling/). | ||||
| ==We only recommend F-Droid as a way to obtain apps which cannot be obtained via the means above.== F-Droid is often recommended as an alternative to Google Play, particularly in the privacy community. The option to add third-party repositories and not be confined to Google's walled garden has led to its popularity. F-Droid additionally has [reproducible builds](https://f-droid.org/en/docs/Reproducible_Builds) for some applications and is dedicated to free and open-source software. However, there are some security-related downsides to how F-Droid builds, signs, and delivers packages: | ||||
|  | ||||
| ## Security comparison of GrapheneOS and CalyxOS | ||||
| ### Profiles | ||||
| CalyxOS includes a device controller app so there is no need to install a third party app like [Shelter](/android/#recommended-apps). GrapheneOS plans to introduce nested profile support with better isolation in the future. | ||||
| Due to their process of building apps, apps in the official F-Droid repository often fall behind on updates. F-Droid maintainers also reuse package IDs while signing apps with their own keys, which is not ideal as it gives the F-Droid team ultimate trust. Additionally, the requirements for an app to be included in the official F-Droid repo are less strict than other app stores like Google Play, meaning that F-Droid tends to host a lot more apps which are older, unmaintained, or otherwise no longer meet [modern security standards](https://developer.android.com/google/play/requirements/target-sdk). | ||||
|  | ||||
| GrapheneOS extends the [user profile](/android/#android-security-privacy) feature allowing a user to press an "End Session" button. This button clears the encryption key from memory. There are plans to add a [cross profile notifications system](https://github.com/GrapheneOS/os-issue-tracker/issues/88) in the future. | ||||
| Other popular third-party repositories for F-Droid such as [IzzyOnDroid](https://apt.izzysoft.de/fdroid) alleviate some of these concerns. The IzzyOnDroid repository pulls builds directly from GitHub and is the next best thing to the developers' own repositories. However, it is not something that we can fully recommend, as apps are typically [removed](https://github.com/vfsfitvnm/ViMusic/issues/240#issuecomment-1225564446) from that repository if they are later added to the main F-Droid repository. While that makes sense (since the goal of that particular repository is to host apps before they're accepted into the main F-Droid repository), it can leave you with installed apps which no longer receive updates. | ||||
|  | ||||
| ### Sandboxed Google Play vs Privileged MicroG | ||||
| When Google Play services are used on GrapheneOS, they run as a user app and are contained within a user or work profile. | ||||
| That said, the [F-Droid](https://f-droid.org/en/packages) and [IzzyOnDroid](https://apt.izzysoft.de/fdroid) repositories are home to countless apps, so they can be a useful tool to search for and discover open-source apps that you can then download through other means such as the Play Store, Aurora Store, or by getting the APK directly from the developer. You should use your best judgement when looking for new apps via this method, and keep an eye on how frequently the app is updated. Outdated apps may rely on unsupported libraries, among other things, posing a potential security risk. | ||||
|  | ||||
| Sandboxed Google Play is confined using the highly restrictive, default [`untrusted_app`](https://source.android.com/security/selinux/concepts) domain provided by [SELinux](https://en.wikipedia.org/wiki/Security-Enhanced_Linux). Permissions for apps to use Google Play Services can be revoked at any time by the user. | ||||
| <div class="admonition note" markdown> | ||||
| <p class="admonition-title">F-Droid Basic</p> | ||||
|  | ||||
| MicroG is a reimplementation of Google Play Services. This means it needs to be updated every time Android has a major version update (or the Android API changes). It also needs to run in the highly privileged [`system_app`](https://source.android.com/security/selinux/concepts) SELinux domain like normal Google Play Services and requires access to [signature spoofing](https://madaidans-insecurities.github.io/android.html#microg-signature-spoofing) so this is less secure than the Sandboxed Google Play approach. We do not believe MicroG provides any privacy advantages over Sandboxed Google Play except for the option to _shift trust_ of the location backend from Google to another provider such as Mozilla or DejaVu. | ||||
| In some rare cases, the developer of an app will only distribute it through F-Droid ([Gadgetbridge](https://gadgetbridge.org) is one example of this). If you really need an app like that, we recommend using the newer [F-Droid Basic](https://f-droid.org/en/packages/org.fdroid.basic) client instead of the original F-Droid app to obtain it. F-Droid Basic supports automatic background updates without privileged extension or root, and has a reduced feature set (limiting attack surface). | ||||
|  | ||||
| From a usability point of view, Sandboxed Google Play also works well with far more applications than MicroG, thanks to its support for services like [Google Play Games](https://play.google.com/googleplaygames) and [In-app Billing API](https://android-doc.github.io/google/play/billing/api.html). | ||||
| </div> | ||||
|  | ||||
| ### 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 installation. | ||||
| ## Criteria | ||||
|  | ||||
| GrapheneOS doesn't compromise on security; therefore, they do not include the F-Droid extension. Users have to confirm all updates manually if they want to use F-Droid. Alternatively, they can use the Droid-ify client which does support seamless app updates in Android 12. GrapheneOS officially recommends [Sandboxed Google Play](https://grapheneos.org/usage#sandboxed-google-play) instead. Many FOSS Android apps are also in Google Play but sometimes they are not (like [NewPipe]({% link _evergreen/video-streaming.md %})). | ||||
| **Please note we are not affiliated with any of the projects we recommend.** In addition to [our standard criteria](about/criteria.md), we have developed a clear set of requirements to allow us to provide objective recommendations. We suggest you familiarize yourself with this list before choosing to use a project, and conduct your own research to ensure it's the right choice for you. | ||||
|  | ||||
| CalyxOS includes the [privileged extension](https://f-droid.org/en/packages/org.fdroid.fdroid.privileged), which may lower device security. Seamless app updates should be possible with [Aurora Store](https://auroraoss.com) in Android 12. | ||||
| ### Operating Systems | ||||
|  | ||||
| ### Additional hardening | ||||
| GrapheneOS improves upon [AOSP](https://source.android.com/) security with: | ||||
| - Must be open-source software. | ||||
| - Must support bootloader locking with custom AVB key support. | ||||
| - Must receive major Android updates within 0-1 months of release. | ||||
| - Must receive Android feature updates (minor version) within 0-14 days of release. | ||||
| - Must receive regular security patches within 0-5 days of release. | ||||
| - Must **not** be "rooted" out of the box. | ||||
| - Must **not** enable Google Play Services by default. | ||||
| - Must **not** require system modification to support Google Play Services. | ||||
|  | ||||
|  -   **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 user installed apps that use WebView will also benefit from Vanadium's hardening. The [Vanadium patch set](https://github.com/GrapheneOS/Vanadium/tree/12/patches) 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). | ||||
| ### Devices | ||||
|  | ||||
| **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). | ||||
| - Must support at least one of our recommended custom operating systems. | ||||
| - Must be currently sold new in stores. | ||||
| - Must receive a minimum of 5 years of security updates. | ||||
| - Must have dedicated secure element hardware. | ||||
|  | ||||
| ### Applications | ||||
|  | ||||
| - Applications on this page must not be applicable to any other software category on the site. | ||||
| - General applications should extend or replace core system functionality. | ||||
| - Applications should receive regular updates and maintenance. | ||||
|   | ||||
| @@ -1,93 +0,0 @@ | ||||
| Copyright (c) 2015 Sebastien Sanfilippo (www.love-letters.be) | ||||
|  | ||||
| This Font Software is licensed under the SIL Open Font License, Version 1.1. | ||||
| This license is copied below, and is also available with a FAQ at: | ||||
| http://scripts.sil.org/OFL | ||||
|  | ||||
|  | ||||
| ----------------------------------------------------------- | ||||
| SIL OPEN FONT LICENSE Version 1.1 - 26 February 2007 | ||||
| ----------------------------------------------------------- | ||||
|  | ||||
| PREAMBLE | ||||
| The goals of the Open Font License (OFL) are to stimulate worldwide | ||||
| development of collaborative font projects, to support the font creation | ||||
| efforts of academic and linguistic communities, and to provide a free and | ||||
| open framework in which fonts may be shared and improved in partnership | ||||
| with others. | ||||
|  | ||||
| The OFL allows the licensed fonts to be used, studied, modified and | ||||
| redistributed freely as long as they are not sold by themselves. The | ||||
| fonts, including any derivative works, can be bundled, embedded,  | ||||
| redistributed and/or sold with any software provided that any reserved | ||||
| names are not used by derivative works. The fonts and derivatives, | ||||
| however, cannot be released under any other type of license. The | ||||
| requirement for fonts to remain under this license does not apply | ||||
| to any document created using the fonts or their derivatives. | ||||
|  | ||||
| DEFINITIONS | ||||
| "Font Software" refers to the set of files released by the Copyright | ||||
| Holder(s) under this license and clearly marked as such. This may | ||||
| include source files, build scripts and documentation. | ||||
|  | ||||
| "Reserved Font Name" refers to any names specified as such after the | ||||
| copyright statement(s). | ||||
|  | ||||
| "Original Version" refers to the collection of Font Software components as | ||||
| distributed by the Copyright Holder(s). | ||||
|  | ||||
| "Modified Version" refers to any derivative made by adding to, deleting, | ||||
| or substituting -- in part or in whole -- any of the components of the | ||||
| Original Version, by changing formats or by porting the Font Software to a | ||||
| new environment. | ||||
|  | ||||
| "Author" refers to any designer, engineer, programmer, technical | ||||
| writer or other person who contributed to the Font Software. | ||||
|  | ||||
| PERMISSION & CONDITIONS | ||||
| Permission is hereby granted, free of charge, to any person obtaining | ||||
| a copy of the Font Software, to use, study, copy, merge, embed, modify, | ||||
| redistribute, and sell modified and unmodified copies of the Font | ||||
| Software, subject to the following conditions: | ||||
|  | ||||
| 1) Neither the Font Software nor any of its individual components, | ||||
| in Original or Modified Versions, may be sold by itself. | ||||
|  | ||||
| 2) Original or Modified Versions of the Font Software may be bundled, | ||||
| redistributed and/or sold with any software, provided that each copy | ||||
| contains the above copyright notice and this license. These can be | ||||
| included either as stand-alone text files, human-readable headers or | ||||
| in the appropriate machine-readable metadata fields within text or | ||||
| binary files as long as those fields can be easily viewed by the user. | ||||
|  | ||||
| 3) No Modified Version of the Font Software may use the Reserved Font | ||||
| Name(s) unless explicit written permission is granted by the corresponding | ||||
| Copyright Holder. This restriction only applies to the primary font name as | ||||
| presented to the users. | ||||
|  | ||||
| 4) The name(s) of the Copyright Holder(s) or the Author(s) of the Font | ||||
| Software shall not be used to promote, endorse or advertise any | ||||
| Modified Version, except to acknowledge the contribution(s) of the | ||||
| Copyright Holder(s) and the Author(s) or with their explicit written | ||||
| permission. | ||||
|  | ||||
| 5) The Font Software, modified or unmodified, in part or in whole, | ||||
| must be distributed entirely under this license, and must not be | ||||
| distributed under any other license. The requirement for fonts to | ||||
| remain under this license does not apply to any document created | ||||
| using the Font Software. | ||||
|  | ||||
| TERMINATION | ||||
| This license becomes null and void if any of the above conditions are | ||||
| not met. | ||||
|  | ||||
| DISCLAIMER | ||||
| THE FONT SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, | ||||
| EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO ANY WARRANTIES OF | ||||
| MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT | ||||
| OF COPYRIGHT, PATENT, TRADEMARK, OR OTHER RIGHT. IN NO EVENT SHALL THE | ||||
| COPYRIGHT HOLDER BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, | ||||
| INCLUDING ANY GENERAL, SPECIAL, INDIRECT, INCIDENTAL, OR CONSEQUENTIAL | ||||
| DAMAGES, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING | ||||
| FROM, OUT OF THE USE OR INABILITY TO USE THE FONT SOFTWARE OR FROM | ||||
| OTHER DEALINGS IN THE FONT SOFTWARE. | ||||
							
								
								
									
										
											BIN
										
									
								
								docs/assets/img/account-deletion/exposed_passwords.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 27 KiB | 
| @@ -1,19 +0,0 @@ | ||||
| <?xml version="1.0"?> | ||||
| <svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" viewBox="-147 -70 294 345"> | ||||
| <g fill="#a4c639"> | ||||
| <use stroke-width="14.4" xlink:href="#b" stroke="#FFF"/> | ||||
| <use xlink:href="#a" transform="scale(-1,1)"/> | ||||
| <g id="a" stroke="#FFF" stroke-width="7.2"> | ||||
| <rect rx="6.5" transform="rotate(29)" height="86" width="13" y="-86" x="14"/> | ||||
| <rect id="c" rx="24" height="133" width="48" y="41" x="-143"/> | ||||
| <use y="97" x="85" xlink:href="#c"/> | ||||
| </g> | ||||
| <g id="b"> | ||||
| <ellipse cy="41" rx="91" ry="84"/> | ||||
| <rect rx="22" height="182" width="182" y="20" x="-91"/> | ||||
| </g> | ||||
| </g> | ||||
| <g stroke="#FFF" stroke-width="7.2" fill="#FFF"> | ||||
| <path d="m-95 44.5h190"/><circle cx="-42" r="4"/><circle cx="42" r="4"/> | ||||
| </g> | ||||
| </svg> | ||||
| Before Width: | Height: | Size: 728 B | 
| @@ -1,2 +0,0 @@ | ||||
| <?xml version="1.0" encoding="UTF-8"?> | ||||
| <svg width="128" height="128" fill="#ffffff" version="1.1" viewBox="0 0 64 64" xmlns="http://www.w3.org/2000/svg"><path d="m29.623 0.50599-20.539 9.1251c-2.1126 0.93891-3.4916 3.0515-3.4916 5.3694v13.79c0 16.284 11.267 31.512 26.407 35.209 15.14-3.697 26.407-18.925 26.407-35.209v-13.79c0-2.3179-1.379-4.4305-3.4916-5.3694l-20.539-9.1251c-1.4964-0.67485-3.2569-0.67485-4.7533 0zm2.3766 31.19h20.539c-1.5551 12.089-9.6239 22.857-20.539 26.231v-26.202h-20.539v-16.724l20.539-9.1251z" stroke-width="2.9341"/></svg> | ||||
| Before Width: | Height: | Size: 551 B | 
| @@ -1,2 +0,0 @@ | ||||
| <?xml version="1.0" encoding="UTF-8"?> | ||||
| <svg width="128" height="128" version="1.1" viewBox="0 0 33.867 33.867" xmlns="http://www.w3.org/2000/svg"><path d="m16.933-1.6667e-7 -13.855 6.1576v9.2364c0 8.5436 5.9113 16.533 13.855 18.473 7.9433-1.9397 13.855-9.9291 13.855-18.473v-9.2364zm0 16.918h10.776c-0.81588 6.3423-5.0492 11.992-10.776 13.762v-13.747h-10.776v-8.7746l10.776-4.7875z" fill="#1a1a1a" stroke-width="1.5394"/><path d="m16.415 18.141h6.35v6.35h-6.35z" fill="none" stroke-width=".26458"/></svg> | ||||
| Before Width: | Height: | Size: 505 B | 
| @@ -1,2 +0,0 @@ | ||||
| <?xml version="1.0" encoding="UTF-8"?> | ||||
| <svg width="128" height="128" version="1.1" viewBox="0 0 33.867 33.867" xmlns="http://www.w3.org/2000/svg"><g transform="matrix(.43429 0 0 .43429 -102.24 -35.595)" stroke-width=".26458"><path d="m313.4 119.93c-7.7343 13.52-22.298 22.631-38.991 22.631-16.692 0-31.256-9.1114-38.991-22.631 7.7346-13.521 22.299-22.632 38.991-22.632 16.693 0 31.257 9.1115 38.991 22.632" fill="#9acc01"/><path d="m298.61 144.6-6.8334-12.569c2.364-3.4422 3.7478-7.6102 3.7478-12.101 0-11.819-9.5811-21.4-21.4-21.4-11.819 0-21.4 9.5806-21.4 21.4 0 11.819 9.5811 21.4 21.4 21.4 4.4736 0 8.6265-1.3727 12.061-3.7206l12.422 6.9937z" fill="#231f20"/><path d="m284.91 125.24c0 5.7915-4.7106 10.502-10.502 10.502-5.7915 0-10.502-4.7106-10.502-10.502v-12.917c0-0.80301 0.65352-1.456 1.4565-1.456 0.80275 0 1.456 0.65299 1.456 1.456v7.8192c0 0.4236 0.34263 0.76623 0.76702 0.76623 8e-3 0 0.0167-2e-3 0.0257-2e-3s0.0164 2e-3 0.0251 2e-3c0.4236 0 0.7665-0.34263 0.7665-0.76623v-11.856c0-0.80354 0.65299-1.4571 1.4565-1.4571s1.4565 0.65352 1.4565 1.4571v11.166c0 0.42387 0.34343 0.76624 0.76677 0.76624 0.42254 0 0.76623-0.34264 0.76623-0.76624v-13.875c0-0.80301 0.65378-1.4555 1.4563-1.4555 0.80354 0 1.4568 0.65246 1.4568 1.4555v13.773c0 0.42413 0.34317 0.76703 0.7665 0.76703 0.42307 0 0.7665-0.34317 0.7665-0.76703v-11.37c0-0.80327 0.65352-1.4565 1.4565-1.4565 0.80327 0 1.456 0.65352 1.456 1.4565v14.555c-1.7436 0.16219-5.8518 1.0464-7.543 5.7222-0.14366 0.39793 0.0622 0.83767 0.46038 0.9824 0.0857 0.031 0.1741 0.0455 0.26009 0.0455 0.31379 0 0.60748-0.19474 0.72125-0.50536 1.7732-4.903 6.6273-4.7546 6.8313-4.7464l0.80354 0.0386v-8.0939c0-0.80301 0.7112-1.4565 1.5843-1.4565 0.87392 0 1.5841 0.65352 1.5841 1.4565v9.2625zm-1.5841-12.253c-0.57864 0-1.1192 0.15557-1.5843 0.41963v-5.4277c0-1.6486-1.3409-2.9901-2.9895-2.9901-0.53314 0-1.0327 0.14261-1.4666 0.38761-0.10398-1.555-1.3991-2.789-2.98-2.789-1.6484 0-2.9893 1.3409-2.9893 2.989v0.10001c-0.4318-0.2413-0.92763-0.381-1.4565-0.381-1.6481 0-2.9893 1.3409-2.9893 2.9901v1.4594c-0.44344-0.26035-0.95752-0.41222-1.5079-0.41222-1.6486 0-2.99 1.3404-2.99 2.9893v12.917c0 6.636 5.3991 12.035 12.036 12.035 6.636 0 12.035-5.3991 12.035-12.035v-9.2631c0-1.6484-1.3981-2.9893-3.1171-2.9893" fill="#9acc01"/></g></svg> | ||||
| Before Width: | Height: | Size: 2.2 KiB | 
| Before Width: | Height: | Size: 7.1 KiB | 
| @@ -1,2 +0,0 @@ | ||||
| <?xml version="1.0" encoding="UTF-8"?> | ||||
| <svg width="128" height="128" version="1.1" viewBox="0 0 33.867 33.867" xmlns="http://www.w3.org/2000/svg"><g transform="translate(0 -263.13)"><g transform="matrix(.072143 0 0 .072143 -44.234 303.31)"><g transform="matrix(.17755 0 0 .17755 641.74 -556.97)" clip-rule="evenodd" fill="#fff" fill-rule="evenodd" image-rendering="optimizeQuality" shape-rendering="geometricPrecision"><path class="fil0" d="m605 798 381-217c-7-21-12-43-12-67 0-92 67-168 155-184v-330h64v330c88 16 155 92 155 184 0 24-5 46-13 67l382 217c14-16 31-30 50-42 80-46 180-26 237 42l286-165 32 56-286 165c31 84-2 180-82 226-18 10-36 17-55 21v442c19 4 37 11 55 21 80 46 113 142 82 226l286 165-32 56-286-165c-57 68-157 88-237 42-19-12-36-26-50-42-127 72-254 145-382 217 8 21 13 43 13 67 0 92-67 168-155 184v330h-64v-330c-88-16-155-92-155-184 0-24 5-46 12-67l-381-217c-14 16-31 30-50 42-80 46-180 26-237-42l-286 165-32-56 286-165c-31-84 2-180 82-226 18-10 36-17 55-21v-442c-19-4-37-11-55-21-80-46-113-142-82-226l-286-165 32-56 286 165c57-68 157-88 237-42 19 12 36 26 50 42zm1080 992c-18-50-15-108 14-157 30-52 81-84 136-92v-438c-55-8-106-40-136-92-29-49-32-107-14-157l-382-218c-35 40-85 65-142 65s-107-25-142-65l-382 218c18 50 15 108-14 157-30 52-81 84-136 92v438c55 8 106 40 136 92 29 49 32 107 14 157l382 218c35-40 85-65 142-65s107 25 142 65z" fill="#fff"/></g></g></g></svg> | ||||
| Before Width: | Height: | Size: 1.4 KiB | 
| @@ -1,2 +0,0 @@ | ||||
| <?xml version="1.0" encoding="UTF-8"?> | ||||
| <svg width="128" height="128" version="1.1" viewBox="0 0 33.867 33.867" xmlns="http://www.w3.org/2000/svg"><g transform="translate(0 -263.13)"><g transform="matrix(.072143 0 0 .072143 -44.234 303.31)"><g transform="matrix(.17755 0 0 .17755 641.74 -556.97)" clip-rule="evenodd" fill="#1b1b1b" fill-rule="evenodd" image-rendering="optimizeQuality" shape-rendering="geometricPrecision"><path class="fil0" d="m605 798 381-217c-7-21-12-43-12-67 0-92 67-168 155-184v-330h64v330c88 16 155 92 155 184 0 24-5 46-13 67l382 217c14-16 31-30 50-42 80-46 180-26 237 42l286-165 32 56-286 165c31 84-2 180-82 226-18 10-36 17-55 21v442c19 4 37 11 55 21 80 46 113 142 82 226l286 165-32 56-286-165c-57 68-157 88-237 42-19-12-36-26-50-42-127 72-254 145-382 217 8 21 13 43 13 67 0 92-67 168-155 184v330h-64v-330c-88-16-155-92-155-184 0-24 5-46 12-67l-381-217c-14 16-31 30-50 42-80 46-180 26-237-42l-286 165-32-56 286-165c-31-84 2-180 82-226 18-10 36-17 55-21v-442c-19-4-37-11-55-21-80-46-113-142-82-226l-286-165 32-56 286 165c57-68 157-88 237-42 19 12 36 26 50 42zm1080 992c-18-50-15-108 14-157 30-52 81-84 136-92v-438c-55-8-106-40-136-92-29-49-32-107-14-157l-382-218c-35 40-85 65-142 65s-107-25-142-65l-382 218c18 50 15 108-14 157-30 52-81 84-136 92v438c55 8 106 40 136 92 29 49 32 107 14 157l382 218c35-40 85-65 142-65s107 25 142 65z" fill="#1b1b1b"/></g></g></g></svg> | ||||
| Before Width: | Height: | Size: 1.4 KiB | 
| @@ -1,2 +0,0 @@ | ||||
| <?xml version="1.0" encoding="UTF-8"?> | ||||
| <svg width="128" height="128" version="1.1" viewBox="0 0 33.867 33.867" xmlns="http://www.w3.org/2000/svg"><g stroke-width=".034914"><circle id="main-circle-drop-shadow" cx="17.283" cy="17.283" r="16.584" fill-opacity=".1"/><circle id="main-circle" cx="16.584" cy="16.584" r="16.584" fill="#4f3663"/><path id="onion-drop-shadow" d="m32.732 20.111c0.11871-0.57958 0.20599-1.1766 0.26186-1.7911l-13.711-13.711-1.0893 1.0474-2.3986-2.3986-1.1626 2.856 1.7946 1.7946-7.5764 20.481 4.4446 4.4446c0.75066 0.14315 1.5048 0.23392 2.2764 0.27582 0.014 4e-3 0.0279 4e-3 0.0419 4e-3h0.014c0.29677 0.0175 0.57958 0.0244 0.8554 0.0244q0.0524 0 0.10474 0c0.35962 0 0.71575-0.0105 1.0509-0.0279 0.0873-3e-3 0.16759-0.0105 0.2444-0.014 0.70527-0.0489 1.3931-0.13966 2.0495-0.26884 0.27931-0.0524 0.55164-0.11522 0.81699-0.17806 2.8211-0.70877 5.314-2.1507 7.4961-4.3329 0.21298-0.21298 0.41898-0.42596 0.61101-0.63894 1.3931-1.5292 2.437-3.1982 3.1388-5.0102 0.31773-0.817 0.56562-1.6654 0.74368-2.5488z" fill-opacity=".2"/></g><g id="onion" transform="matrix(.034914 0 0 .034914 -1.2918 -1.2918)"><path id="first-layer" d="m433.1 252.1v13.4c-1.7 42.1-20 72.8-54.8 92.2-3 1.5-6.1 3-9.1 4.7-26.7 14.2-51.7 32.9-74.8 56-60.1 60.2-90.2 132.8-90.2 217.8 0 85.1 30.1 157.7 90.2 217.8 60.2 60.2 132.8 90.2 217.8 90.2h4.1v-678.4c-28.7-2.2-56.4-7.8-83.1-13.6z" fill="#fdfcdf"/><circle id="second-layer" cx="512" cy="645" r="235" fill="#eaeace"/><circle id="third-layer" cx="512" cy="648" r="162" fill="#d1d1b8"/><circle id="fourth-layer" cx="512" cy="650" r="94" fill="#bfbfa9"/><path id="half" d="m820.1 636.1q0-127.6-90.2-217.8c-23.8-23.8-49.7-43-77.8-57.5-38.1-17.6-58.4-50.5-61-98.6-25.7 4.9-50.6 5.4-74.9 3.6v678.5c83.5-1 154.6-31.1 213.7-90.2 60.2-60.1 90.2-132.7 90.2-217.8z" fill="#735a93"/><path id="leafs" d="m443.4 84.4c-0.3 1.3-0.7 2.6-0.9 3.7q-31 121.9 65.2 161.7c18.8-62.2-0.9-116-59.3-161.7-1.4-1.1-3.1-2.4-4.8-3.7zm81 165.4c-5.4-40.8 16.3-67.9 64.9-80.8-5.3 44.9-26.9 71.8-64.9 80.8" fill="#78af52"/></g></svg> | ||||
| Before Width: | Height: | Size: 2.0 KiB | 
| @@ -1,2 +0,0 @@ | ||||
| <?xml version="1.0" encoding="UTF-8"?> | ||||
| <svg width="128" height="128" version="1.1" viewBox="0 0 33.867 33.867" xmlns="http://www.w3.org/2000/svg"><defs><mask id="mask-2" fill="#ffffff"><circle cx="384" cy="384" r="384"/></mask></defs><g id="Group" transform="scale(.044097)" fill-rule="evenodd" mask="url(#mask-2)"><rect id="Rectangle" width="192" height="192" fill="#0d2e46"/><rect x="192" width="192" height="192" fill="#415a6e"/><rect x="384" width="192" height="192" fill="#597961"/><rect x="576" width="192" height="192" fill="#6d4048"/><rect x="576" y="192" width="192" height="192" fill="#e08f88"/><rect x="384" y="192" width="192" height="192" fill="#e3b59c"/><rect x="192" y="192" width="192" height="192" fill="#8ba281"/><rect y="192" width="192" height="192" fill="#6378ab"/><rect y="384" width="192" height="192" fill="#7d5a49"/><rect x="192" y="384" width="192" height="192" fill="#b48268"/><rect x="384" y="384" width="192" height="192" fill="#8f595b"/><rect x="576" y="384" width="192" height="192" fill="#ebe0d3"/><rect x="576" y="576" width="192" height="192" fill="#5f495d"/><rect x="384" y="576" width="192" height="192" fill="#b1a0b8"/><rect x="192" y="576" width="192" height="192" fill="#fbeee9"/><rect y="576" width="192" height="192" fill="#c08679"/></g></svg> | ||||
| Before Width: | Height: | Size: 1.3 KiB | 
							
								
								
									
										
											BIN
										
									
								
								docs/assets/img/android/rss-apk-dark.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 50 KiB | 
							
								
								
									
										
											BIN
										
									
								
								docs/assets/img/android/rss-apk-light.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 47 KiB | 
							
								
								
									
										
											BIN
										
									
								
								docs/assets/img/android/rss-changes-dark.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 96 KiB | 
							
								
								
									
										
											BIN
										
									
								
								docs/assets/img/android/rss-changes-light.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 93 KiB | 
| @@ -1,2 +0,0 @@ | ||||
| <?xml version="1.0" encoding="UTF-8"?> | ||||
| <svg fill="#ffffff" version="1.1" viewBox="0 0 128 128" xmlns="http://www.w3.org/2000/svg"><g transform="scale(5.3333)"><path d="m0 0h24v24h-24z" fill="none"/><circle cx="12" cy="12" r="3"/><path d="m20 4h-3.17l-1.24-1.35c-0.37-0.41-0.91-0.65-1.47-0.65h-4.24c-0.56 0-1.1 0.24-1.48 0.65l-1.23 1.35h-3.17c-1.1 0-2 0.9-2 2v12c0 1.1 0.9 2 2 2h16c1.1 0 2-0.9 2-2v-12c0-1.1-0.9-2-2-2zm-8 13c-2.76 0-5-2.24-5-5s2.24-5 5-5 5 2.24 5 5-2.24 5-5 5z"/></g></svg> | ||||
| Before Width: | Height: | Size: 490 B | 
| @@ -1,2 +0,0 @@ | ||||
| <?xml version="1.0" encoding="UTF-8"?> | ||||
| <svg width="128" height="128" version="1.1" viewBox="0 0 33.867 33.867" xmlns="http://www.w3.org/2000/svg"><g stroke-width="1.4111"><path d="m0-1.13e-6h33.867v33.867h-33.867z" fill="none"/><circle cx="16.933" cy="16.933" r="4.2333"/><path d="m28.222 5.6444h-4.4732l-1.7498-1.905c-0.52213-0.57856-1.2841-0.91722-2.0743-0.91722h-5.9831c-0.79022 0-1.5522 0.33867-2.0884 0.91722l-1.7357 1.905h-4.4732c-1.5522 0-2.8222 1.27-2.8222 2.8222v16.933c0 1.5522 1.27 2.8222 2.8222 2.8222h22.578c1.5522 0 2.8222-1.27 2.8222-2.8222v-16.933c0-1.5522-1.27-2.8222-2.8222-2.8222zm-11.289 18.344c-3.8947 0-7.0556-3.1609-7.0556-7.0556s3.1609-7.0556 7.0556-7.0556c3.8947 0 7.0556 3.1609 7.0556 7.0556s-3.1609 7.0556-7.0556 7.0556z"/></g></svg> | ||||
| Before Width: | Height: | Size: 761 B | 
| @@ -1,2 +0,0 @@ | ||||
| <?xml version="1.0" encoding="UTF-8"?> | ||||
| <svg fill="#ffffff" version="1.1" viewBox="0 0 128 128" xmlns="http://www.w3.org/2000/svg"><path d="m52 52h24v24h-24z" fill="none"/><path d="m112 0h-96c-8.8 0-16 7.2-16 16v96c0 8.8 7.2 16 16 16h96c8.8 0 16-7.2 16-16v-96c0-8.8-7.2-16-16-16zm-68 60c0 6.64-5.36 12-12 12h-8v10c0 3.28-2.72 6-6 6s-6-2.72-6-6v-34c0-4.4 3.6-8 8-8h12c6.64 0 12 5.36 12 12zm40 16c0 6.64-5.36 12-12 12h-16c-2.24 0-4-1.76-4-4v-40c0-2.24 1.76-4 4-4h16c6.64 0 12 5.36 12 12zm32-30c0 3.28-2.72 6-6 6h-6v8h6c3.28 0 6 2.72 6 6s-2.72 6-6 6h-6v10c0 3.28-2.72 6-6 6s-6-2.72-6-6v-34c0-4.4 3.6-8 8-8h10c3.28 0 6 2.72 6 6zm-92 14h8v-8h-8zm40 16h8v-24h-8z" stroke-width="8"/></svg> | ||||
| Before Width: | Height: | Size: 682 B | 
| @@ -1,2 +0,0 @@ | ||||
| <?xml version="1.0" encoding="UTF-8"?> | ||||
| <svg width="128" height="128" version="1.1" viewBox="0 0 33.867 33.867" xmlns="http://www.w3.org/2000/svg"><path d="m29.633 8.2833e-7h-25.4c-2.3283 0-4.2333 1.905-4.2333 4.2333v25.4c0 2.3283 1.905 4.2333 4.2333 4.2333h25.4c2.3283 0 4.2333-1.905 4.2333-4.2333v-25.4c0-2.3283-1.905-4.2333-4.2333-4.2333zm-17.992 15.875c0 1.7568-1.4182 3.175-3.175 3.175h-2.1167v2.6458c0 0.86783-0.71967 1.5875-1.5875 1.5875s-1.5875-0.71967-1.5875-1.5875v-8.9958c0-1.1642 0.9525-2.1167 2.1167-2.1167h3.175c1.7568 0 3.175 1.4182 3.175 3.175zm10.583 4.2333c0 1.7568-1.4182 3.175-3.175 3.175h-4.2333c-0.59267 0-1.0583-0.46567-1.0583-1.0583v-10.583c0-0.59267 0.46567-1.0583 1.0583-1.0583h4.2333c1.7568 0 3.175 1.4182 3.175 3.175zm8.4667-7.9375c0 0.86783-0.71967 1.5875-1.5875 1.5875h-1.5875v2.1167h1.5875c0.86784 0 1.5875 0.71967 1.5875 1.5875s-0.71967 1.5875-1.5875 1.5875h-1.5875v2.6458c0 0.86783-0.71967 1.5875-1.5875 1.5875-0.86783 0-1.5875-0.71967-1.5875-1.5875v-8.9958c0-1.1642 0.9525-2.1167 2.1167-2.1167h2.6458c0.86784 0 1.5875 0.71967 1.5875 1.5875zm-24.342 3.7042h2.1167v-2.1167h-2.1167zm10.583 4.2333h2.1167v-6.35h-2.1167z" stroke-width="2.1167"/></svg> | ||||
| Before Width: | Height: | Size: 1.2 KiB | 
| Before Width: | Height: | Size: 8.6 KiB | 
| Before Width: | Height: | Size: 11 KiB |