mirror of
				https://github.com/privacyguides/privacyguides.org.git
				synced 2025-10-26 09:12:10 +00:00 
			
		
		
		
	Compare commits
	
		
			25 Commits
		
	
	
		
			2024.03.31
			...
			35dc235a9d
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 35dc235a9d | ||
|   | 6d34aa1f7d | ||
|   | d988800738 | ||
|   | 090645b150 | ||
|   | cb9d760c56 | ||
|   | 4a42d8e1fe | ||
|   | 5820c4d945 | ||
| 1372587017 | |||
| 82ab189d36 | |||
| 139a206367 | |||
|   | e8a1e5bfa0 | ||
|   | d137e1acf3 | ||
|   | 07efd74ca1 | ||
|   | beff5eb145 | ||
|   | e3e9faaeba | ||
|   | 3aa43c0e4e | ||
|   | 00926206cc | ||
|   | c64d5e6795 | ||
|   | 88724b7833 | ||
|   | 10e68cd44b | ||
|   | adc97bc8b1 | ||
|   | 6bc7782a42 | ||
|   | e42533fa1b | ||
|   | 0e07ccaf50 | ||
|   | ccb08456a2 | 
							
								
								
									
										3
									
								
								.github/workflows/build-offline.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										3
									
								
								.github/workflows/build-offline.yml
									
									
									
									
										vendored
									
									
								
							| @@ -52,7 +52,6 @@ jobs: | ||||
|       - name: Python setup | ||||
|         uses: actions/setup-python@v5 | ||||
|         with: | ||||
|           python-version: '3.8' | ||||
|           cache: 'pipenv' | ||||
|  | ||||
|       - uses: actions/cache/restore@v4.0.2 | ||||
| @@ -105,7 +104,7 @@ jobs: | ||||
|           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 /data/privacy_guides.zim | ||||
|             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 /data/offline-privacy_guides.zim | ||||
|  | ||||
|       - name: Upload ZIM file | ||||
|         uses: actions/upload-artifact@v4 | ||||
|   | ||||
							
								
								
									
										3
									
								
								.github/workflows/build.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										3
									
								
								.github/workflows/build.yml
									
									
									
									
										vendored
									
									
								
							| @@ -55,6 +55,7 @@ jobs: | ||||
|           repository: ${{ inputs.repo }} | ||||
|           ref: ${{ inputs.ref }} | ||||
|           persist-credentials: 'false' | ||||
|           fetch-depth: 0 | ||||
|  | ||||
|       - uses: actions/download-artifact@v4 | ||||
|         with: | ||||
| @@ -75,7 +76,6 @@ jobs: | ||||
|  | ||||
|       - uses: actions/setup-python@v5 | ||||
|         with: | ||||
|           python-version: '3.8' | ||||
|           cache: 'pipenv' | ||||
|  | ||||
|       - uses: actions/cache/restore@v4.0.2 | ||||
| @@ -106,6 +106,7 @@ jobs: | ||||
|         with: | ||||
|           path: includes/strings.${{ inputs.lang }}.env | ||||
|           export-variables: true | ||||
|           keys-case: bypass | ||||
|  | ||||
|       - env: | ||||
|           GH_TOKEN: ${{ secrets.GITHUB_TOKEN }} | ||||
|   | ||||
							
								
								
									
										72
									
								
								.github/workflows/deploy.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										72
									
								
								.github/workflows/deploy.yml
									
									
									
									
										vendored
									
									
								
							| @@ -31,11 +31,19 @@ on: | ||||
|         type: boolean | ||||
|       github_pages: | ||||
|         type: boolean | ||||
|       bunnycdn_production: | ||||
|         type: boolean | ||||
|       minio_production: | ||||
|         type: boolean | ||||
|     outputs: | ||||
|       netlify_preview_address: | ||||
|         value: ${{ jobs.netlify_preview.outputs.address }} | ||||
|     secrets: | ||||
|       NETLIFY_TOKEN: | ||||
|       PROD_BUNNYCDN_API_KEY: | ||||
|       PROD_BUNNYCDN_PASSWORD: | ||||
|       PROD_MINIO_KEY_ID: | ||||
|       PROD_MINIO_SECRET_KEY: | ||||
|  | ||||
| jobs: | ||||
|   netlify_preview: | ||||
| @@ -90,7 +98,7 @@ jobs: | ||||
|  | ||||
|     environment: | ||||
|       name: production | ||||
|       url: https://www.privacyguides.org | ||||
|       url: https://illustrious-bavarois-56cf30.netlify.app/ | ||||
|  | ||||
|     steps: | ||||
|       - uses: actions/download-artifact@v4 | ||||
| @@ -165,3 +173,65 @@ jobs: | ||||
|  | ||||
|       - id: deployment | ||||
|         uses: actions/deploy-pages@main | ||||
|  | ||||
|   bunnycdn_production: | ||||
|     if: inputs.bunnycdn_production | ||||
|     runs-on: ubuntu-latest | ||||
|  | ||||
|     permissions: | ||||
|       contents: read | ||||
|  | ||||
|     environment: | ||||
|       name: production | ||||
|       url: https://privacyguides-org-production.b-cdn.net | ||||
|  | ||||
|     steps: | ||||
|       - uses: actions/download-artifact@v4 | ||||
|         with: | ||||
|           pattern: site-build-* | ||||
|           merge-multiple: true | ||||
|  | ||||
|       - run: | | ||||
|           for file in *.tar.gz; do tar -zxf "$file"; done | ||||
|           ls -la site/ | ||||
|  | ||||
|       - uses: own3d/bunny-action@bfaa5c6bc8b7a7ebd599ddd4912347d7c3847e78 | ||||
|         env: | ||||
|           BUNNY_API_ACCESS_KEY: ${{ secrets.PROD_BUNNYCDN_API_KEY }} | ||||
|           BUNNY_STORAGE_HOSTNAME: storage.bunnycdn.com | ||||
|           BUNNY_STORAGE_USERNAME: ${{ vars.PROD_BUNNYCDN_USER }} | ||||
|           BUNNY_STORAGE_PASSWORD: ${{ secrets.PROD_BUNNYCDN_PASSWORD }} | ||||
|           BUNNY_PULL_ZONE_ID: 2117106 | ||||
|         with: | ||||
|           args: deploy --dir=site | ||||
|  | ||||
|   minio_production: | ||||
|     if: inputs.minio_production | ||||
|     runs-on: ubuntu-latest | ||||
|  | ||||
|     permissions: | ||||
|       contents: read | ||||
|  | ||||
|     environment: | ||||
|       name: production | ||||
|       url: https://privacyguides-org-production.stor1-minio.jonaharagon.net | ||||
|  | ||||
|     steps: | ||||
|       - uses: actions/download-artifact@v4 | ||||
|         with: | ||||
|           pattern: site-build-* | ||||
|           merge-multiple: true | ||||
|  | ||||
|       - run: | | ||||
|           for file in *.tar.gz; do tar -zxf "$file"; done | ||||
|           ls -la site/ | ||||
|  | ||||
|       - uses: jakejarvis/s3-sync-action@master | ||||
|         with: | ||||
|           args: --acl public-read --follow-symlinks --delete | ||||
|         env: | ||||
|           SOURCE_DIR: "site/" | ||||
|           AWS_S3_BUCKET: ${{ vars.PROD_MINIO_BUCKET }} | ||||
|           AWS_S3_ENDPOINT: ${{ vars.PROD_MINIO_HOSTNAME }} | ||||
|           AWS_ACCESS_KEY_ID: ${{ secrets.PROD_MINIO_KEY_ID }} | ||||
|           AWS_SECRET_ACCESS_KEY: ${{ secrets.PROD_MINIO_SECRET_KEY }} | ||||
|   | ||||
							
								
								
									
										3
									
								
								.github/workflows/publish-pr.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										3
									
								
								.github/workflows/publish-pr.yml
									
									
									
									
										vendored
									
									
								
							| @@ -97,5 +97,6 @@ jobs: | ||||
|           comment_tag: deployment | ||||
|  | ||||
|   cleanup: | ||||
|     needs: deploy | ||||
|     if: ${{ always() }} | ||||
|     needs: build | ||||
|     uses: ./.github/workflows/cleanup.yml | ||||
|   | ||||
							
								
								
									
										6
									
								
								.github/workflows/publish-release.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										6
									
								
								.github/workflows/publish-release.yml
									
									
									
									
										vendored
									
									
								
							| @@ -88,8 +88,14 @@ jobs: | ||||
|     with: | ||||
|       netlify_production: true | ||||
|       github_pages: true | ||||
|       bunnycdn_production: true | ||||
|       minio_production: true | ||||
|     secrets: | ||||
|       NETLIFY_TOKEN: ${{ secrets.NETLIFY_TOKEN }} | ||||
|       PROD_BUNNYCDN_API_KEY: ${{ secrets.PROD_BUNNYCDN_API_KEY }} | ||||
|       PROD_BUNNYCDN_PASSWORD: ${{ secrets.PROD_BUNNYCDN_PASSWORD }} | ||||
|       PROD_MINIO_KEY_ID: ${{ secrets.PROD_MINIO_KEY_ID }} | ||||
|       PROD_MINIO_SECRET_KEY: ${{ secrets.PROD_MINIO_SECRET_KEY }} | ||||
|  | ||||
|   cleanup: | ||||
|     if: ${{ always() }} | ||||
|   | ||||
							
								
								
									
										64
									
								
								.github/workflows/test-build.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										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: ./.github/workflows/download-repo.yml | ||||
|     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: ./.github/workflows/cleanup.yml | ||||
| @@ -1 +1 @@ | ||||
| 3.8 | ||||
| 3.12 | ||||
|   | ||||
| @@ -1,2 +0,0 @@ | ||||
| brew "pngquant" | ||||
| brew "crowdin" | ||||
| @@ -1 +0,0 @@ | ||||
| brew "pngquant" | ||||
							
								
								
									
										7
									
								
								Pipfile
									
									
									
									
									
								
							
							
						
						
									
										7
									
								
								Pipfile
									
									
									
									
									
								
							| @@ -24,15 +24,14 @@ verify_ssl = true | ||||
| name = "pypi" | ||||
|  | ||||
| [packages] | ||||
| mkdocs-material = {path = "./modules/mkdocs-material"} | ||||
| 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" | ||||
| pillow = "~=10.0" | ||||
| cairosvg = "~=2.7" | ||||
| jieba = "~=0.42" | ||||
|  | ||||
| [dev-packages] | ||||
| scour = "~=0.38" | ||||
|  | ||||
| [requires] | ||||
| python_version = "3.8" | ||||
| python_version = "3.12" | ||||
|   | ||||
							
								
								
									
										244
									
								
								Pipfile.lock
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										244
									
								
								Pipfile.lock
									
									
									
										generated
									
									
									
								
							| @@ -1,11 +1,11 @@ | ||||
| { | ||||
|     "_meta": { | ||||
|         "hash": { | ||||
|             "sha256": "fd39f7100d809e16f8cc4d8a332f0c2b41f10db166678f87c06e23c795383768" | ||||
|             "sha256": "93ebf65ff6386809b3bea7cadd6e1eb71f8b0bb066846d81ec8d95422d32af64" | ||||
|         }, | ||||
|         "pipfile-spec": 6, | ||||
|         "requires": { | ||||
|             "python_version": "3.8" | ||||
|             "python_version": "3.12" | ||||
|         }, | ||||
|         "sources": [ | ||||
|             { | ||||
| @@ -29,7 +29,7 @@ | ||||
|                 "sha256:74e3d1928edc070d21748185c46e3fb33490f22f52a3addee9aee0f4f7781051", | ||||
|                 "sha256:b80878c9f40111313e55da8ba20bdba06d8fa3969fc68304167741bbf9e082ed" | ||||
|             ], | ||||
|             "markers": "python_version >= '3.6'", | ||||
|             "markers": "python_full_version >= '3.6.0'", | ||||
|             "version": "==4.12.3" | ||||
|         }, | ||||
|         "cairocffi": { | ||||
| @@ -45,7 +45,7 @@ | ||||
|                 "sha256:432531d72347291b9a9ebfb6777026b607563fd8719c46ee742db0aef7271ba0", | ||||
|                 "sha256:8a5222d4e6c3f86f1f7046b63246877a63b49923a1cd202184c3a634ef546b3b" | ||||
|             ], | ||||
|             "index": "pypi", | ||||
|             "markers": "python_version >= '3.5'", | ||||
|             "version": "==2.7.1" | ||||
|         }, | ||||
|         "certifi": { | ||||
| @@ -207,7 +207,7 @@ | ||||
|                 "sha256:fd1abc0d89e30cc4e02e4064dc67fcc51bd941eb395c502aac3ec19fab46b519", | ||||
|                 "sha256:ff8fa367d09b717b2a17a052544193ad76cd49979c805768879cb63d9ca50561" | ||||
|             ], | ||||
|             "markers": "python_version >= '3.7'", | ||||
|             "markers": "python_full_version >= '3.7.0'", | ||||
|             "version": "==3.3.2" | ||||
|         }, | ||||
|         "click": { | ||||
| @@ -259,11 +259,11 @@ | ||||
|         }, | ||||
|         "gitpython": { | ||||
|             "hashes": [ | ||||
|                 "sha256:1bf9cd7c9e7255f77778ea54359e54ac22a72a5b51288c457c881057b7bb9ecd", | ||||
|                 "sha256:2d99869e0fef71a73cbd242528105af1d6c1b108c60dfabd994bf292f76c3ceb" | ||||
|                 "sha256:35f314a9f878467f5453cc1fee295c3e18e52f1b99f10f6cf5b1682e968a9e7c", | ||||
|                 "sha256:eec7ec56b92aad751f9912a73404bc02ba212a23adb2c7098ee668417051a1ff" | ||||
|             ], | ||||
|             "markers": "python_version >= '3.7'", | ||||
|             "version": "==3.1.42" | ||||
|             "version": "==3.1.43" | ||||
|         }, | ||||
|         "idna": { | ||||
|             "hashes": [ | ||||
| @@ -273,13 +273,12 @@ | ||||
|             "markers": "python_version >= '3.5'", | ||||
|             "version": "==3.6" | ||||
|         }, | ||||
|         "importlib-metadata": { | ||||
|         "jieba": { | ||||
|             "hashes": [ | ||||
|                 "sha256:30962b96c0c223483ed6cc7280e7f0199feb01a0e40cfae4d4450fc6fab1f570", | ||||
|                 "sha256:b78938b926ee8d5f020fc4772d487045805a55ddbad2ecf21c6d60938dc7fcd2" | ||||
|                 "sha256:055ca12f62674fafed09427f176506079bc135638a14e23e25be909131928db2" | ||||
|             ], | ||||
|             "markers": "python_version < '3.10'", | ||||
|             "version": "==7.1.0" | ||||
|             "index": "pypi", | ||||
|             "version": "==0.42.1" | ||||
|         }, | ||||
|         "jinja2": { | ||||
|             "hashes": [ | ||||
| @@ -291,87 +290,122 @@ | ||||
|         }, | ||||
|         "lxml": { | ||||
|             "hashes": [ | ||||
|                 "sha256:13521a321a25c641b9ea127ef478b580b5ec82aa2e9fc076c86169d161798b01", | ||||
|                 "sha256:14deca1460b4b0f6b01f1ddc9557704e8b365f55c63070463f6c18619ebf964f", | ||||
|                 "sha256:16018f7099245157564d7148165132c70adb272fb5a17c048ba70d9cc542a1a1", | ||||
|                 "sha256:16dd953fb719f0ffc5bc067428fc9e88f599e15723a85618c45847c96f11f431", | ||||
|                 "sha256:19a1bc898ae9f06bccb7c3e1dfd73897ecbbd2c96afe9095a6026016e5ca97b8", | ||||
|                 "sha256:1ad17c20e3666c035db502c78b86e58ff6b5991906e55bdbef94977700c72623", | ||||
|                 "sha256:22b7ee4c35f374e2c20337a95502057964d7e35b996b1c667b5c65c567d2252a", | ||||
|                 "sha256:24ef5a4631c0b6cceaf2dbca21687e29725b7c4e171f33a8f8ce23c12558ded1", | ||||
|                 "sha256:25663d6e99659544ee8fe1b89b1a8c0aaa5e34b103fab124b17fa958c4a324a6", | ||||
|                 "sha256:262bc5f512a66b527d026518507e78c2f9c2bd9eb5c8aeeb9f0eb43fcb69dc67", | ||||
|                 "sha256:280f3edf15c2a967d923bcfb1f8f15337ad36f93525828b40a0f9d6c2ad24890", | ||||
|                 "sha256:2ad3a8ce9e8a767131061a22cd28fdffa3cd2dc193f399ff7b81777f3520e372", | ||||
|                 "sha256:2befa20a13f1a75c751f47e00929fb3433d67eb9923c2c0b364de449121f447c", | ||||
|                 "sha256:2f37c6d7106a9d6f0708d4e164b707037b7380fcd0b04c5bd9cae1fb46a856fb", | ||||
|                 "sha256:304128394c9c22b6569eba2a6d98392b56fbdfbad58f83ea702530be80d0f9df", | ||||
|                 "sha256:342e95bddec3a698ac24378d61996b3ee5ba9acfeb253986002ac53c9a5f6f84", | ||||
|                 "sha256:3aeca824b38ca78d9ee2ab82bd9883083d0492d9d17df065ba3b94e88e4d7ee6", | ||||
|                 "sha256:3d184e0d5c918cff04cdde9dbdf9600e960161d773666958c9d7b565ccc60c45", | ||||
|                 "sha256:3e3898ae2b58eeafedfe99e542a17859017d72d7f6a63de0f04f99c2cb125936", | ||||
|                 "sha256:3eea6ed6e6c918e468e693c41ef07f3c3acc310b70ddd9cc72d9ef84bc9564ca", | ||||
|                 "sha256:3f14a4fb1c1c402a22e6a341a24c1341b4a3def81b41cd354386dcb795f83897", | ||||
|                 "sha256:436a943c2900bb98123b06437cdd30580a61340fbdb7b28aaf345a459c19046a", | ||||
|                 "sha256:4946e7f59b7b6a9e27bef34422f645e9a368cb2be11bf1ef3cafc39a1f6ba68d", | ||||
|                 "sha256:49a9b4af45e8b925e1cd6f3b15bbba2c81e7dba6dce170c677c9cda547411e14", | ||||
|                 "sha256:4f8b0c78e7aac24979ef09b7f50da871c2de2def043d468c4b41f512d831e912", | ||||
|                 "sha256:52427a7eadc98f9e62cb1368a5079ae826f94f05755d2d567d93ee1bc3ceb354", | ||||
|                 "sha256:5e53d7e6a98b64fe54775d23a7c669763451340c3d44ad5e3a3b48a1efbdc96f", | ||||
|                 "sha256:5fcfbebdb0c5d8d18b84118842f31965d59ee3e66996ac842e21f957eb76138c", | ||||
|                 "sha256:601f4a75797d7a770daed8b42b97cd1bb1ba18bd51a9382077a6a247a12aa38d", | ||||
|                 "sha256:61c5a7edbd7c695e54fca029ceb351fc45cd8860119a0f83e48be44e1c464862", | ||||
|                 "sha256:6a2a2c724d97c1eb8cf966b16ca2915566a4904b9aad2ed9a09c748ffe14f969", | ||||
|                 "sha256:6d48fc57e7c1e3df57be5ae8614bab6d4e7b60f65c5457915c26892c41afc59e", | ||||
|                 "sha256:6f11b77ec0979f7e4dc5ae081325a2946f1fe424148d3945f943ceaede98adb8", | ||||
|                 "sha256:704f5572ff473a5f897745abebc6df40f22d4133c1e0a1f124e4f2bd3330ff7e", | ||||
|                 "sha256:725e171e0b99a66ec8605ac77fa12239dbe061482ac854d25720e2294652eeaa", | ||||
|                 "sha256:7cfced4a069003d8913408e10ca8ed092c49a7f6cefee9bb74b6b3e860683b45", | ||||
|                 "sha256:7ec465e6549ed97e9f1e5ed51c657c9ede767bc1c11552f7f4d022c4df4a977a", | ||||
|                 "sha256:82bddf0e72cb2af3cbba7cec1d2fd11fda0de6be8f4492223d4a268713ef2147", | ||||
|                 "sha256:82cd34f1081ae4ea2ede3d52f71b7be313756e99b4b5f829f89b12da552d3aa3", | ||||
|                 "sha256:843b9c835580d52828d8f69ea4302537337a21e6b4f1ec711a52241ba4a824f3", | ||||
|                 "sha256:877efb968c3d7eb2dad540b6cabf2f1d3c0fbf4b2d309a3c141f79c7e0061324", | ||||
|                 "sha256:8b9f19df998761babaa7f09e6bc169294eefafd6149aaa272081cbddc7ba4ca3", | ||||
|                 "sha256:8cf5877f7ed384dabfdcc37922c3191bf27e55b498fecece9fd5c2c7aaa34c33", | ||||
|                 "sha256:8d2900b7f5318bc7ad8631d3d40190b95ef2aa8cc59473b73b294e4a55e9f30f", | ||||
|                 "sha256:8d7b4beebb178e9183138f552238f7e6613162a42164233e2bda00cb3afac58f", | ||||
|                 "sha256:8f52fe6859b9db71ee609b0c0a70fea5f1e71c3462ecf144ca800d3f434f0764", | ||||
|                 "sha256:98f3f020a2b736566c707c8e034945c02aa94e124c24f77ca097c446f81b01f1", | ||||
|                 "sha256:9aa543980ab1fbf1720969af1d99095a548ea42e00361e727c58a40832439114", | ||||
|                 "sha256:9b99f564659cfa704a2dd82d0684207b1aadf7d02d33e54845f9fc78e06b7581", | ||||
|                 "sha256:9bcf86dfc8ff3e992fed847c077bd875d9e0ba2fa25d859c3a0f0f76f07f0c8d", | ||||
|                 "sha256:9bd0ae7cc2b85320abd5e0abad5ccee5564ed5f0cc90245d2f9a8ef330a8deae", | ||||
|                 "sha256:9d3c0f8567ffe7502d969c2c1b809892dc793b5d0665f602aad19895f8d508da", | ||||
|                 "sha256:9e5ac3437746189a9b4121db2a7b86056ac8786b12e88838696899328fc44bb2", | ||||
|                 "sha256:a36c506e5f8aeb40680491d39ed94670487ce6614b9d27cabe45d94cd5d63e1e", | ||||
|                 "sha256:a5ab722ae5a873d8dcee1f5f45ddd93c34210aed44ff2dc643b5025981908cda", | ||||
|                 "sha256:a96f02ba1bcd330807fc060ed91d1f7a20853da6dd449e5da4b09bfcc08fdcf5", | ||||
|                 "sha256:acb6b2f96f60f70e7f34efe0c3ea34ca63f19ca63ce90019c6cbca6b676e81fa", | ||||
|                 "sha256:ae15347a88cf8af0949a9872b57a320d2605ae069bcdf047677318bc0bba45b1", | ||||
|                 "sha256:af8920ce4a55ff41167ddbc20077f5698c2e710ad3353d32a07d3264f3a2021e", | ||||
|                 "sha256:afd825e30f8d1f521713a5669b63657bcfe5980a916c95855060048b88e1adb7", | ||||
|                 "sha256:b21b4031b53d25b0858d4e124f2f9131ffc1530431c6d1321805c90da78388d1", | ||||
|                 "sha256:b4b68c961b5cc402cbd99cca5eb2547e46ce77260eb705f4d117fd9c3f932b95", | ||||
|                 "sha256:b66aa6357b265670bb574f050ffceefb98549c721cf28351b748be1ef9577d93", | ||||
|                 "sha256:b9e240ae0ba96477682aa87899d94ddec1cc7926f9df29b1dd57b39e797d5ab5", | ||||
|                 "sha256:bc64d1b1dab08f679fb89c368f4c05693f58a9faf744c4d390d7ed1d8223869b", | ||||
|                 "sha256:bf8443781533b8d37b295016a4b53c1494fa9a03573c09ca5104550c138d5c05", | ||||
|                 "sha256:c26aab6ea9c54d3bed716b8851c8bfc40cb249b8e9880e250d1eddde9f709bf5", | ||||
|                 "sha256:c3cd1fc1dc7c376c54440aeaaa0dcc803d2126732ff5c6b68ccd619f2e64be4f", | ||||
|                 "sha256:c7257171bb8d4432fe9d6fdde4d55fdbe663a63636a17f7f9aaba9bcb3153ad7", | ||||
|                 "sha256:d42e3a3fc18acc88b838efded0e6ec3edf3e328a58c68fbd36a7263a874906c8", | ||||
|                 "sha256:d74fcaf87132ffc0447b3c685a9f862ffb5b43e70ea6beec2fb8057d5d2a1fea", | ||||
|                 "sha256:d8c1d679df4361408b628f42b26a5d62bd3e9ba7f0c0e7969f925021554755aa", | ||||
|                 "sha256:e856c1c7255c739434489ec9c8aa9cdf5179785d10ff20add308b5d673bed5cd", | ||||
|                 "sha256:eac68f96539b32fce2c9b47eb7c25bb2582bdaf1bbb360d25f564ee9e04c542b", | ||||
|                 "sha256:ed7326563024b6e91fef6b6c7a1a2ff0a71b97793ac33dbbcf38f6005e51ff6e", | ||||
|                 "sha256:ed8c3d2cd329bf779b7ed38db176738f3f8be637bb395ce9629fc76f78afe3d4", | ||||
|                 "sha256:f4c9bda132ad108b387c33fabfea47866af87f4ea6ffb79418004f0521e63204", | ||||
|                 "sha256:f643ffd2669ffd4b5a3e9b41c909b72b2a1d5e4915da90a77e119b8d48ce867a" | ||||
|                 "sha256:0382e6a3eefa3f6699b14fa77c2eb32af2ada261b75120eaf4fc028a20394975", | ||||
|                 "sha256:03e3962d6ad13a862dacd5b3a3ea60b4d092a550f36465234b8639311fd60989", | ||||
|                 "sha256:05fc3720250d221792b6e0d150afc92d20cb10c9cdaa8c8f93c2a00fbdd16015", | ||||
|                 "sha256:06036d60fccb21e22dd167f6d0e422b9cbdf3588a7e999a33799f9cbf01e41a5", | ||||
|                 "sha256:0947d1114e337dc2aae2fa14bbc9ed5d9ca1a0acd6d2f948df9926aef65305e9", | ||||
|                 "sha256:0e95ae029396382a0d2e8174e4077f96befcd4a2184678db363ddc074eb4d3b2", | ||||
|                 "sha256:11acfcdf5a38cf89c48662123a5d02ae0a7d99142c7ee14ad90de5c96a9b6f06", | ||||
|                 "sha256:11e41ffd3cd27b0ca1c76073b27bd860f96431d9b70f383990f1827ca19f2f52", | ||||
|                 "sha256:1459a998c10a99711ac532abe5cc24ba354e4396dafef741c7797f8830712d56", | ||||
|                 "sha256:16e65223f34fd3d65259b174f0f75a4bb3d9893698e5e7d01e54cd8c5eb98d85", | ||||
|                 "sha256:1cce2eaad7e38b985b0f91f18468dda0d6b91862d32bec945b0e46e2ffe7222e", | ||||
|                 "sha256:1eace37a9f4a1bef0bb5c849434933fd6213008ec583c8e31ee5b8e99c7c8500", | ||||
|                 "sha256:1ede2a7a86a977b0c741654efaeca0af7860a9b1ae39f9268f0936246a977ee0", | ||||
|                 "sha256:1effc10bf782f0696e76ecfeba0720ea02c0c31d5bffb7b29ba10debd57d1c3d", | ||||
|                 "sha256:200f70b5d95fc79eb9ed7f8c4888eef4e274b9bf380b829d3d52e9ed962e9231", | ||||
|                 "sha256:21dc490cdb33047bc7f7ad76384f3366fa8f5146b86cc04c4af45de901393b90", | ||||
|                 "sha256:246c93e2503c710cf02c7e9869dc0258223cbefe5e8f9ecded0ac0aa07fd2bf8", | ||||
|                 "sha256:25fef8794f0dc89f01bdd02df6a7fec4bcb2fbbe661d571e898167a83480185e", | ||||
|                 "sha256:27877732946843f4b6bfc56eb40d865653eef34ad2edeed16b015d5c29c248df", | ||||
|                 "sha256:281ee1ffeb0ab06204dfcd22a90e9003f0bb2dab04101ad983d0b1773bc10588", | ||||
|                 "sha256:2a34e74ffe92c413f197ff4967fb1611d938ee0691b762d062ef0f73814f3aa4", | ||||
|                 "sha256:2ad364026c2cebacd7e01d1138bd53639822fefa8f7da90fc38cd0e6319a2699", | ||||
|                 "sha256:2bbe335f0d1a86391671d975a1b5e9b08bb72fba6b567c43bdc2e55ca6e6c086", | ||||
|                 "sha256:32d44af078485c4da9a7ec460162392d49d996caf89516fa0b75ad0838047122", | ||||
|                 "sha256:347ec08250d5950f5b016caa3e2e13fb2cb9714fe6041d52e3716fb33c208663", | ||||
|                 "sha256:356f8873b1e27b81793e30144229adf70f6d3e36e5cb7b6d289da690f4398953", | ||||
|                 "sha256:35e39c6fd089ad6674eb52d93aa874d6027b3ae44d2381cca6e9e4c2e102c9c8", | ||||
|                 "sha256:3603a8a41097daf7672cae22cc4a860ab9ea5597f1c5371cb21beca3398b8d6a", | ||||
|                 "sha256:371aab9a397dcc76625ad3b02fa9b21be63406d69237b773156e7d1fc2ce0cae", | ||||
|                 "sha256:3ac7c8a60b8ad51fe7bca99a634dd625d66492c502fd548dc6dc769ce7d94b6a", | ||||
|                 "sha256:3cefb133c859f06dab2ae63885d9f405000c4031ec516e0ed4f9d779f690d8e3", | ||||
|                 "sha256:3f06e4460e76468d99cc36d5b9bc6fc5f43e6662af44960e13e3f4e040aacb35", | ||||
|                 "sha256:4add722393c99da4d51c8d9f3e1ddf435b30677f2d9ba9aeaa656f23c1b7b580", | ||||
|                 "sha256:4c232726f7b6df5143415a06323faaa998ef8abbe1c0ed00d718755231d76f08", | ||||
|                 "sha256:4d16b44ad0dd8c948129639e34c8d301ad87ebc852568ace6fe9a5ad9ce67ee1", | ||||
|                 "sha256:50a26f68d090594477df8572babac64575cd5c07373f7a8319c527c8e56c0f99", | ||||
|                 "sha256:5188f22c00381cb44283ecb28c8d85c2db4a3035774dd851876c8647cb809c27", | ||||
|                 "sha256:5261c858c390ae9a19aba96796948b6a2d56649cbd572968970dc8da2b2b2a42", | ||||
|                 "sha256:52d6cdea438eb7282c41c5ac00bd6d47d14bebb6e8a8d2a1c168ed9e0cacfbab", | ||||
|                 "sha256:53c0e56f41ef68c1ce4e96f27ecdc2df389730391a2fd45439eb3facb02d36c8", | ||||
|                 "sha256:56591e477bea531e5e1854f5dfb59309d5708669bc921562a35fd9ca5182bdcd", | ||||
|                 "sha256:56835b9e9a7767202fae06310c6b67478963e535fe185bed3bf9af5b18d2b67e", | ||||
|                 "sha256:57402d6cdd8a897ce21cf8d1ff36683583c17a16322a321184766c89a1980600", | ||||
|                 "sha256:57cbadf028727705086047994d2e50124650e63ce5a035b0aa79ab50f001989f", | ||||
|                 "sha256:5810fa80e64a0c689262a71af999c5735f48c0da0affcbc9041d1ef5ef3920be", | ||||
|                 "sha256:59ec2948385336e9901008fdf765780fe30f03e7fdba8090aafdbe5d1b7ea0cd", | ||||
|                 "sha256:5f6e4e5a62114ae76690c4a04c5108d067442d0a41fd092e8abd25af1288c450", | ||||
|                 "sha256:60847dfbdfddf08a56c4eefe48234e8c1ab756c7eda4a2a7c1042666a5516564", | ||||
|                 "sha256:60a3983d32f722a8422c01e4dc4badc7a307ca55c59e2485d0e14244a52c482f", | ||||
|                 "sha256:641a8da145aca67671205f3e89bfec9815138cf2fe06653c909eab42e486d373", | ||||
|                 "sha256:6a7e0935f05e1cf1a3aa1d49a87505773b04f128660eac2a24a5594ea6b1baa7", | ||||
|                 "sha256:6e45fd5213e5587a610b7e7c8c5319a77591ab21ead42df46bb342e21bc1418d", | ||||
|                 "sha256:6f0d2b97a5a06c00c963d4542793f3e486b1ed3a957f8c19f6006ed39d104bb0", | ||||
|                 "sha256:703d60e59ab45c17485c2c14b11880e4f7f0eab07134afa9007573fa5a779a5a", | ||||
|                 "sha256:7250030a7835bfd5ba6ca7d1ad483ec90f9cbc29978c5e75c1cc3e031d3c4160", | ||||
|                 "sha256:73e69762cf740ac3ae81137ef9d6f15f93095f50854e233d50b29e7b8a91dbc6", | ||||
|                 "sha256:75a4117b43694c72a0d89f6c18a28dc57407bde4650927d4ef5fd384bdf6dcc7", | ||||
|                 "sha256:7a1611fb9de0a269c05575c024e6d8cdf2186e3fa52b364e3b03dcad82514d57", | ||||
|                 "sha256:7c556bbf88a8b667c849d326dd4dd9c6290ede5a33383ffc12b0ed17777f909d", | ||||
|                 "sha256:7c61ce3cdd6e6c9f4003ac118be7eb3036d0ce2afdf23929e533e54482780f74", | ||||
|                 "sha256:7efbce96719aa275d49ad5357886845561328bf07e1d5ab998f4e3066c5ccf15", | ||||
|                 "sha256:7fac15090bb966719df06f0c4f8139783746d1e60e71016d8a65db2031ca41b8", | ||||
|                 "sha256:80cc2b55bb6e35d3cb40936b658837eb131e9f16357241cd9ba106ae1e9c5ecb", | ||||
|                 "sha256:883e382695f346c2ea3ad96bdbdf4ca531788fbeedb4352be3a8fcd169fc387d", | ||||
|                 "sha256:8aa11638902ac23f944f16ce45c9f04c9d5d57bb2da66822abb721f4efe5fdbb", | ||||
|                 "sha256:92bb37c96215c4b2eb26f3c791c0bf02c64dd251effa532b43ca5049000c4478", | ||||
|                 "sha256:931a3a13e0f574abce8f3152b207938a54304ccf7a6fd7dff1fdb2f6691d08af", | ||||
|                 "sha256:93eede9bcc842f891b2267c7f0984d811940d1bc18472898a1187fe560907a99", | ||||
|                 "sha256:947fa8bf15d1c62c6db36c6ede9389cac54f59af27010251747f05bddc227745", | ||||
|                 "sha256:a00f5931b7cccea775123c3c0a2513aee58afdad8728550cc970bff32280bdd2", | ||||
|                 "sha256:a3c39def0965e8fb5c8d50973e0c7b4ce429a2fa730f3f9068a7f4f9ce78410b", | ||||
|                 "sha256:a9b67b850ab1d304cb706cf71814b0e0c3875287083d7ec55ee69504a9c48180", | ||||
|                 "sha256:ada8ce9e6e1d126ef60d215baaa0c81381ba5841c25f1d00a71cdafdc038bd27", | ||||
|                 "sha256:ae550cbd7f229cdf2841d9b01406bcca379a5fb327b9efb53ba620a10452e835", | ||||
|                 "sha256:ae69524fd6a68b288574013f8fadac23cacf089c75cd3fc5b216277a445eb736", | ||||
|                 "sha256:af64df85fecd3cf3b2e792f0b5b4d92740905adfa8ce3b24977a55415f1a0c40", | ||||
|                 "sha256:b0181c22fdb89cc19e70240a850e5480817c3e815b1eceb171b3d7a3aa3e596a", | ||||
|                 "sha256:b03531f6cd6ce4b511dcece060ca20aa5412f8db449274b44f4003f282e6272f", | ||||
|                 "sha256:b3b4bb89a785f4fd60e05f3c3a526c07d0d68e3536f17f169ca13bf5b5dd75a5", | ||||
|                 "sha256:b7150e630b879390e02121e71ceb1807f682b88342e2ea2082e2c8716cf8bd93", | ||||
|                 "sha256:b8f842df9ba26135c5414e93214e04fe0af259bb4f96a32f756f89467f7f3b45", | ||||
|                 "sha256:ba3a86b0d5a5c93104cb899dff291e3ae13729c389725a876d00ef9696de5425", | ||||
|                 "sha256:ba4d02aed47c25be6775a40d55c5774327fdedba79871b7c2485e80e45750cb2", | ||||
|                 "sha256:bc2259243ee734cc736e237719037efb86603c891fd363cc7973a2d0ac8a0e3f", | ||||
|                 "sha256:be5c8e776ecbcf8c1bce71a7d90e3a3680c9ceae516cac0be08b47e9fac0ca43", | ||||
|                 "sha256:be5faa2d5c8c8294d770cfd09d119fb27b5589acc59635b0cf90f145dbe81dca", | ||||
|                 "sha256:c53164f29ed3c3868787144e8ea8a399ffd7d8215f59500a20173593c19e96eb", | ||||
|                 "sha256:c54f8d6160080831a76780d850302fdeb0e8d0806f661777b0714dfb55d9a08a", | ||||
|                 "sha256:c74e77df9e36c8c91157853e6cd400f6f9ca7a803ba89981bfe3f3fc7e5651ef", | ||||
|                 "sha256:c84dce8fb2e900d4fb094e76fdad34a5fd06de53e41bddc1502c146eb11abd74", | ||||
|                 "sha256:ca3236f31d565555139d5b00b790ed2a98ac6f0c4470c4032f8b5e5a5dba3c1a", | ||||
|                 "sha256:d2b339fb790fc923ae2e9345c8633e3d0064d37ea7920c027f20c8ae6f65a91f", | ||||
|                 "sha256:d46df6f0b1a0cda39d12c5c4615a7d92f40342deb8001c7b434d7c8c78352e58", | ||||
|                 "sha256:da12b4efc93d53068888cb3b58e355b31839f2428b8f13654bd25d68b201c240", | ||||
|                 "sha256:dc7b630c4fb428b8a40ddd0bfc4bc19de11bb3c9b031154f77360e48fe8b4451", | ||||
|                 "sha256:dd0f25a431cd16f70ec1c47c10b413e7ddfe1ccaaddd1a7abd181e507c012374", | ||||
|                 "sha256:ddbea6e58cce1a640d9d65947f1e259423fc201c9cf9761782f355f53b7f3097", | ||||
|                 "sha256:ddda5ba8831f258ac7e6364be03cb27aa62f50c67fd94bc1c3b6247959cc0369", | ||||
|                 "sha256:df7dfbdef11702fd22c2eaf042d7098d17edbc62d73f2199386ad06cbe466f6d", | ||||
|                 "sha256:e08784288a179b59115b5e57abf6d387528b39abb61105fe17510a199a277a40", | ||||
|                 "sha256:e283b24c14361fe9e04026a1d06c924450415491b83089951d469509900d9f32", | ||||
|                 "sha256:e4366e58c0508da4dee4c7c70cee657e38553d73abdffa53abbd7d743711ee11", | ||||
|                 "sha256:e6cb8f7a332eaa2d876b649a748a445a38522e12f2168e5e838d1505a91cdbb7", | ||||
|                 "sha256:e8359fb610c8c444ac473cfd82dae465f405ff807cabb98a9b9712bbd0028751", | ||||
|                 "sha256:eaf5e308a5e50bc0548c4fdca0117a31ec9596f8cfc96592db170bcecc71a957", | ||||
|                 "sha256:ed1fe80e1fcdd1205a443bddb1ad3c3135bb1cd3f36cc996a1f4aed35960fbe8", | ||||
|                 "sha256:f1f164e4cc6bc646b1fc86664c3543bf4a941d45235797279b120dc740ee7af5", | ||||
|                 "sha256:f2cb157e279d28c66b1c27e0948687dc31dc47d1ab10ce0cd292a8334b7de3d5", | ||||
|                 "sha256:f354d62345acdf22aa3e171bd9723790324a66fafe61bfe3873b86724cf6daaa", | ||||
|                 "sha256:f46f8033da364bacc74aca5e319509a20bb711c8a133680ca5f35020f9eaf025", | ||||
|                 "sha256:f90c36ca95a44d2636bbf55a51ca30583b59b71b6547b88d954e029598043551", | ||||
|                 "sha256:f9e27841cddfaebc4e3ffbe5dbdff42891051acf5befc9f5323944b2c61cef16", | ||||
|                 "sha256:fadda215e32fe375d65e560b7f7e2a37c7f9c4ecee5315bb1225ca6ac9bf5838" | ||||
|             ], | ||||
|             "markers": "python_version >= '3.6'", | ||||
|             "version": "==5.1.0" | ||||
|             "version": "==5.2.0" | ||||
|         }, | ||||
|         "markdown": { | ||||
|             "hashes": [ | ||||
| @@ -469,6 +503,7 @@ | ||||
|                 "sha256:921da26b3f4393e6c170279ac34089151dfc22cd29ec4fbce3506218541685c8" | ||||
|             ], | ||||
|             "index": "pypi", | ||||
|             "markers": "python_version >= '3.8' and python_version < '4'", | ||||
|             "version": "==1.2.0" | ||||
|         }, | ||||
|         "mkdocs-git-revision-date-localized-plugin": { | ||||
| @@ -477,6 +512,7 @@ | ||||
|                 "sha256:1f94eb510862ef94e982a2910404fa17a1657ecf29f45a07b0f438c00767fc85" | ||||
|             ], | ||||
|             "index": "pypi", | ||||
|             "markers": "python_version >= '3.8'", | ||||
|             "version": "==1.2.4" | ||||
|         }, | ||||
|         "mkdocs-macros-plugin": { | ||||
| @@ -485,11 +521,14 @@ | ||||
|                 "sha256:fe348d75f01c911f362b6d998c57b3d85b505876dde69db924f2c512c395c328" | ||||
|             ], | ||||
|             "index": "pypi", | ||||
|             "markers": "python_version >= '3.8'", | ||||
|             "version": "==1.0.5" | ||||
|         }, | ||||
|         "mkdocs-material": { | ||||
|             "path": "./modules/mkdocs-material", | ||||
|             "version": "==9.5.15+insiders.4.53.3" | ||||
|             "extras": [ | ||||
|                 "imaging" | ||||
|             ], | ||||
|             "path": "./modules/mkdocs-material" | ||||
|         }, | ||||
|         "mkdocs-material-extensions": { | ||||
|             "hashes": [ | ||||
| @@ -592,7 +631,7 @@ | ||||
|                 "sha256:f379abd2f1e3dddb2b61bc67977a6b5a0a3f7485538bcc6f39ec76163891ee48", | ||||
|                 "sha256:fe4c15f6c9285dc54ce6553a3ce908ed37c8f3825b5a51a15c91442bb955b868" | ||||
|             ], | ||||
|             "index": "pypi", | ||||
|             "markers": "python_version >= '3.8'", | ||||
|             "version": "==10.2.0" | ||||
|         }, | ||||
|         "platformdirs": { | ||||
| @@ -605,10 +644,11 @@ | ||||
|         }, | ||||
|         "pycparser": { | ||||
|             "hashes": [ | ||||
|                 "sha256:8ee45429555515e1f6b185e78100aea234072576aa43ab53aefcae078162fca9", | ||||
|                 "sha256:e644fdec12f7872f86c58ff790da456218b10f863970249516d60a5eaca77206" | ||||
|                 "sha256:491c8be9c040f5390f5bf44a5b07752bd07f56edf992381b05c701439eec10f6", | ||||
|                 "sha256:c3702b6d3dd8c7abc1afa565d7e63d53a1d0bd86cdc24edd75470f4de499cfcc" | ||||
|             ], | ||||
|             "version": "==2.21" | ||||
|             "markers": "python_version >= '3.8'", | ||||
|             "version": "==2.22" | ||||
|         }, | ||||
|         "pygments": { | ||||
|             "hashes": [ | ||||
| @@ -903,14 +943,6 @@ | ||||
|                 "sha256:b36a1c245f2d304965eb4e0a82848379241dc04b865afcc4aab16748587e1923" | ||||
|             ], | ||||
|             "version": "==0.5.1" | ||||
|         }, | ||||
|         "zipp": { | ||||
|             "hashes": [ | ||||
|                 "sha256:206f5a15f2af3dbaee80769fb7dc6f249695e940acca08dfb2a4769fe61e538b", | ||||
|                 "sha256:2884ed22e7d8961de1c9a05142eb69a247f120291bc0206a00a7642f09b5b715" | ||||
|             ], | ||||
|             "markers": "python_version >= '3.8'", | ||||
|             "version": "==3.18.1" | ||||
|         } | ||||
|     }, | ||||
|     "develop": { | ||||
|   | ||||
| @@ -92,7 +92,7 @@ This website uses [`mkdocs-material-insiders`](https://squidfunk.github.io/mkdoc | ||||
|  | ||||
| 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.8**, this is the only version supported by Netlify | ||||
| 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: `pipenv run mkdocs serve --config-file config/mkdocs.en.yml` (set `CARDS=true` to generate social cards) | ||||
|   | ||||
| @@ -229,6 +229,7 @@ nav: | ||||
|       - 'os/linux-overview.md' | ||||
|       - 'os/macos-overview.md' | ||||
|       - 'os/qubes-overview.md' | ||||
|       - 'os/windows-overview.md' | ||||
|     - kb-archive.md | ||||
|   - !ENV [NAV_RECOMMENDATIONS, 'Recommendations']: | ||||
|     - 'tools.md' | ||||
|   | ||||
							
								
								
									
										411
									
								
								docs/os/windows-overview.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										411
									
								
								docs/os/windows-overview.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,411 @@ | ||||
| --- | ||||
| title: Windows Overview | ||||
| icon: simple/windows | ||||
| description: Windows is a traditonal operating system developed by Microsoft that provides a platform for running software applications and managing computer hardware. | ||||
| --- | ||||
|  | ||||
| Windows, a renowned desktop operating system developed by Microsoft, made its debut in 1985. It boasts a broad user base across various hardware manufacturers. Nonetheless, it grapples with issues such as bloatware, intrusive tracking, and security vulnerabilities. This guide aims to address and mitigate these concerns to enhance your Windows experience, though complete elimination may not be achievable. | ||||
|  | ||||
| ## Hardware and Firmware Security | ||||
|  | ||||
| ### Choosing a Secure Hardware | ||||
|  | ||||
| - Choose a secured-core PC that has long-term lifetime support. The Microsoft Surface for Business series is the best option in this regard. | ||||
| - Choose a PC with Microsoft Pluton. | ||||
|  | ||||
| <details class="note" markdown> | ||||
| <summary>Secure Launch and Secure Boot</summary> | ||||
|  | ||||
| TBC | ||||
|  | ||||
| </details> | ||||
|  | ||||
| ### Firmware Settings | ||||
|  | ||||
| - Enable Secure Boot and, if applicable, disable the third-party Microsoft UEFI CA.  | ||||
| - Enable Virtualization settings. | ||||
| - Enable Dynamic Root of Trust for Measurement (DRTM). | ||||
| - If available, set Thunderbolt Security Settings to the highest level. | ||||
| - Be sure to set a firmware password. | ||||
| - Configure Boot Sequence to exclusively boot from your hard drive while disabling all other items, if accessible. | ||||
| - Enable Trusted Platform Module (TPM) and designate Microsoft Pluton as default if applicable. | ||||
|  | ||||
| ## Operating System Security | ||||
|  | ||||
| ### Choose the Correct Version and Edition | ||||
|  | ||||
| Use Windows 11 Enterprise, version 23H2 as your operating system.  | ||||
|  | ||||
| ### Out-of-Box-Experience (OOBE) | ||||
|  | ||||
| - Select your region to European Union (EU) and allow optional diagnostic data. | ||||
| - Use a local account instead of a Microsoft account. | ||||
| - After OOBE, enable Smart App Control in Start → Windows Security → App & Browser Control → Smart App Control. | ||||
|  | ||||
| <details class="note" markdown> | ||||
| <summary>Activate Windows Enterprise</summary> | ||||
|  | ||||
| For Key Management Service (KMS) activation, execute the following command from an elevated command prompt: | ||||
|  | ||||
| ``` | ||||
| cd "c:\windows\system32" | ||||
| cscript slmgr.vbs /skms input.your.kms.server.here | ||||
| cscript slmgr.vbs /ato | ||||
| ``` | ||||
|  | ||||
| For Multiple Activation Key (MAK) activation, execute the following command from an elevated command prompt: | ||||
|  | ||||
| ``` | ||||
| cd "c:\windows\system32" | ||||
| cscript slmgr.vbs /ipk input-your-mak-key-here | ||||
| cscript slmgr.vbs /ato | ||||
| ``` | ||||
|  | ||||
| </details> | ||||
|  | ||||
| <details class="note" markdown> | ||||
| <summary>Upgrade Windows</summary> | ||||
|  | ||||
| To upgrade from Windows Home to Windows Pro, enter your product key in Sttings → System → Activation → Change product key. | ||||
|  | ||||
| To upgrade from Windows Pro to Windows Enterprise, execute the following command from an elevated command prompt: | ||||
|  | ||||
| ``` | ||||
| cd "c:\windows\system32" | ||||
| cscript slmgr.vbs /ipk NPPR9-FWDCX-D2C8J-H872K-2YT43 | ||||
| cscript slmgr.vbs /ato | ||||
| ``` | ||||
|  | ||||
| Please note that the above command will not activate Windows Enterprise. | ||||
| </details> | ||||
|  | ||||
| <details class="info" markdown> | ||||
| <summary>Command Prompt and Group Policy</summary> | ||||
|  | ||||
| TBC | ||||
|  | ||||
| </details> | ||||
|  | ||||
| ### Install Updates | ||||
|  | ||||
| Installing updates is crucial. Windows Update delivers updates to Windows automatically. You can also manually check for updates in Start → Settings → Windows Update → Check for Updates. You should [update](https://learn.microsoft.com/en-us/windows-hardware/manufacture/desktop/add-update-to-winre?view=windows-11#apply-the-update-to-a-running-pc) Windows Recovery Environment (Windows RE) by yourself. If you have other Windows installation media, such as Windows Preinstallation Environment (Windows PE) or Windows RE that is not recognized by the current Windows operating system, you should [update](https://learn.microsoft.com/en-us/windows/deployment/update/media-dynamic-update) them manually.  | ||||
|  | ||||
| You can track update packages for Windows operating system, Windows RE and Windows PE using [this](https://support.microsoft.com/en-us/feed/rss/4ec863cc-2ecd-e187-6cb3-b50c6545db92) RSS feed. *Compatibility update for installing and recovering Windows* denotes updates for Windows RE. *Setup Dynamic Update for Windows* denotes updates for Windows PE. You can download update packages from the [Microsoft Update Catalog](https://www.catalog.update.microsoft.com/Home.aspx). | ||||
|  | ||||
| You should also enable automatic updates in Microsoft Store in Start → Microsoft Store → Personal Profile → Settings → App Updates. You can also obtain drivers and firmware updates from original equipment manufacturers (OEMs). | ||||
|  | ||||
| <details class="info" markdown> | ||||
| <summary>Types of Windows updates</summary> | ||||
|  | ||||
| **Feature updates** are released annually to add new features and functionality to Windows. | ||||
|  | ||||
| **Quality updates**, which encompass security and non-security fixes such as security updates, critical updates, servicing stack updates, and driver updates, are typically released on the second Tuesday of each month but can be released at any time. | ||||
|  | ||||
| </details> | ||||
|  | ||||
| ### Security Baselines | ||||
|  | ||||
| A security baseline is a group of Microsoft-recommended configuration settings that explains their security implication. | ||||
|  | ||||
| - [Download](https://www.microsoft.com/en-us/download/details.aspx?id=55319) the following files: `Windows 11 v23H2 Security Baseline.zip` and `LGPO.zip`. | ||||
| - Unzip both files. In `LGPO\LGPO_30`, copy `LGPO.exe` to `Windows 11 v23H2 Security Baseline\Scripts\Tools`. | ||||
| - In `Windows 11 v23H2 Security Baseline\Scripts`, execute the following command from an elevated command prompt: | ||||
|   ``` | ||||
|   Set-ExecutionPolicy -Scope Process Unrestricted | ||||
|   .\Baseline-LocalInstall.ps1 -Win11NonDomainJoined | ||||
|   ``` | ||||
|  | ||||
| You can track security baseline updates using [this](https://techcommunity.microsoft.com/gxcuf89792/rss/board?board.id=Microsoft-Security-Baselines) RSS feed. | ||||
|  | ||||
| ### Application Security | ||||
|  | ||||
| Most applications on Windows are not sandboxed. In Microsoft Store, only the apps without the permission "This app can access all your files, peripheral devices, apps, programs, and registry" are sandboxed. If you sideload apps, only those with the file extensions `.msix`, `.msixbundle`, `.appx`, `.appxbundle`, and without the permission "This app can access all your files, peripheral devices, apps, programs, and registry" are sandboxed. | ||||
|  | ||||
| Smart App Control can check the security of apps while they are running. You should enable Smart App Control in Start → Windows Security → App & Browser Control → Smart App Control. | ||||
|  | ||||
| You can also use Windows Sandbox to run untrusted apps. Enable Windows Sandbox in Start → Settings → System → Optional Fetures → More Windows Features. Open Windows Sandbox in Start → Windows Sandbox. You can transfer files and apps into Windows Sandbox by copying them. | ||||
|  | ||||
| ### Device Encryption | ||||
|  | ||||
| BitLocker is a disk encryption feature. Before enabling Bitlocker, you should configure it to use stronger encryption methods as well as allow for more secure unlocking methods: | ||||
|  | ||||
| - Enable the Group Policy `Computer Configuration\Administrative Templates\Windows Components\BitLocker Drive Encryption\Choose drive encryption method and cipher strength (Windows 10 [Version 1511] and later)` and set the options to `XTS-AES 256-bit`, `XTS-AES 256-bit`, `AES-CBC 256-bit` respectively. | ||||
| - Enable the Group Policy `Computer Configuration\Administrative Templates\Windows Components\BitLocker Drive Encryption\Operating System Drives\Require additional authentication at startup` and set the options to unchecked, `Allow TPM`, `Allow startup PIN with TPM`, `Allow startup key with TPM` and `Allow startup key and PIN with TPM` respectively. | ||||
| - Enable the Group Policy `Computer Configuration\Administrative Templates\Windows Components\BitLocker Drive Encryption\Operating System Drives\Allow enhanced PINs for startup`. | ||||
|  | ||||
| You should enable Bitlocker in Start → Windows Security → Device Security → Data Encryption. You should set a strong PIN for BitLocker and encrypt the entire disk space. | ||||
|  | ||||
| ### Antivirus Protection | ||||
|  | ||||
| Windows include Windows Security, which provides the latest antivirus protection. | ||||
|  | ||||
| - Enable all options in Start → Windows Security → App & Browser Control → Reputation Based Protection. | ||||
| - Enable all options in Start → Windows Security → App & Browser Control → Exploit Protection → System Settings. | ||||
| - Enable all options in Start → Windows Security → Virus & Threat Protection → Virus & Threat Protection Settings. | ||||
| - Enable the option in Start → Windows Security → Virus & Threat Protection → Ransomware Protection → Controlled Folder Access. | ||||
| - Enable `Block all inbound connections` options in Start → Windows Security → Firewall and Network Protection → Public Network/Private Network/Domain Network. | ||||
| - Check if `Memory access protection` is displayed in Start → Windows Security → Device Security → Core Isolation. If not, enable the Group Policy `Computer Configuration\Administrative Templates\Windows Components\BitLocker Drive Encryption\Disable new DMA devices when this computer is locked`. | ||||
| - Enable the Group Policy `Computer Configuration\Administrative Templates\Windows Components\Microsoft Defender Antivirus\Scan\Turn on e-mail scanning`. | ||||
| - Enable the Group Policy `Computer Configuration\Administrative Templates\Windows Components\Microsoft Defender Antivirus\Scan\Scan removable drives`. | ||||
| - Enable the Group Policy `Computer Configuration\Administrative Templates\Windows Components\Microsoft Defender Antivirus\Scan\Scan network files`. | ||||
| - Enable the Group Policy `Computer Configuration\Administrative Templates\Windows Components\Microsoft Defender Antivirus\Scan\Run full scan on mapped network drives`. | ||||
| - Execute `setx /M MP_FORCE_USE_SANDBOX 1` from an elevated command prompt. | ||||
|  | ||||
| ### Account Security | ||||
|  | ||||
| You should use a local user account for daily tasks. Use complex passwords for your accounts. You can create a local user account in Start → Settings → Accounts → Other users → Add account → I don't have this person's sign-in information → Add a user without a Microsoft account. You should add security questions to your local account in case you forget your password in Start  → Settings → Accounts → Sign-in options → Update your security questions. You can also create a password reset disk for your local account. In the search box on the taskbar, type `Control Panel`, and then choose it from the list of results. In the Control Panel search box, type `create password reset`. Select `Create a password reset disk`, and follow the remaining instructions. | ||||
|  | ||||
| You can hide your account info when logging in by enabling the Group Policy `Computer Configuration\Windows Settings\Security Settings\Local Policies\Security Options\Interactive logon: Don’t display last signed-in` and `Computer Configuration\Windows Settings\Security Settings\Local Policies\Security Options\Interactive logon: Don’t display username at sign-in`. You can also find the related option in Start → Settings → Accounts → Sign-in Options → Show account details such as my email address on the sign-in screen. | ||||
|  | ||||
| ### Network & Bluetooth Security | ||||
|  | ||||
| - Disable all options in Start → Settings → Network & Internet → Advanced Network Setings → Advanced Sharing Setings → Private Networks/Public Networks. Set options in Start → Settings → Network & Internet → Advanced Network Setings → Advanced Sharing Setings → All Networks to disable public folder sharing, use 128-bit encryption and enable password protected sharing. | ||||
| - Enable MAC Address Randomization in Start → Settings → Network & Internet → Wi-Fi → Random Hardware Addresses and set the option in Start → Settings → Network & Internet → Wi-Fi → (Your Network Display Name) → Random Hardware Addresses to `Change every day`. | ||||
| - Turn off Bluetooth when not in use. Disable device discovery in Start → Settings → Devices → Devices → More Bluetooth Settings. | ||||
| - Set your encrypted DNS in Start → Settings → Network & Internet → Wi-Fi → (Your Network Properties) → DNS Server Assignment → Edit → Manual. | ||||
|  | ||||
| ### Developer Mode | ||||
|  | ||||
| - Disable Developer Mode in Start → Settings → System → For Developers → Developer Mode. | ||||
| - Disable Remote Desktop in Start → Settings → System → For Developers → Remote Desktop. | ||||
| - Enable all options in Start → Settings → System → For Developers → File Explorer. | ||||
|  | ||||
| ### Additional Attack Surface Reduction Measures | ||||
|  | ||||
| In addition to the security baselines, there are some additional attack surface reduction measures. | ||||
|  | ||||
| - Disable Remote Assistance. In the search box on the taskbar, type `remote assistance`, and then select `Allow Remote Assistance invitations to be sent from this computer` from the list of results. Then, on the `Remote` tab, unselect the Allow Remote Assistance connections to this computer check box, and then select OK. | ||||
| - Uninstall features you won't use like Internet Explorer mode in Start → Settings → System → Optional Fetures and Start → Settings → System → Optional Fetures → More Windows Features. | ||||
| - Enable the Group Policy `Computer Configuration\Administrative Templates\MS Security Guide\Enable Certificate Padding`. | ||||
| - Add additional attack surface reduction rules and set them to warn mode. Enable the Group Policy `Computer Configuration\Administrative Templates\Windows Components\Microsoft Defender Antivirus\Microsoft Defender Exploit Guard\Attack surface reduction\Configure Attack Surface Reduction rules`. Select `Show...` and add the following [rule IDs](https://learn.microsoft.com/en-us/microsoft-365/security/defender-endpoint/attack-surface-reduction-rules-reference?view=o365-worldwide#asr-rule-to-guid-matrix) in the Value Name column. Then change the status of all rules to 6 in the Value column. | ||||
|   ``` | ||||
|   56a863a9-875e-4185-98a7-b882c64b5ce5 | ||||
|   d1e49aac-8f56-4280-b9ba-993a6d77406c | ||||
|   01443614-cd74-433a-b99e-2ecdc07bfc25 | ||||
|   ``` | ||||
| - Execute the following command from an elevated command prompt: | ||||
|   ``` | ||||
|   reg add "HKEY_LOCAL_MACHINE\System\CurrentControlSet\Control\Lsa" /v DisableRestrictedAdmin /t REG_DWORD /d 0 /f | ||||
|   reg add "HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Ole\AppCompat\OLELinkConversionFromOLESTREAMToIStorage" /v Disabled /t REG_DWORD /d 1 /f | ||||
|   ``` | ||||
| - Enable [additional mitigations](https://support.microsoft.com/en-us/topic/kb4073119-windows-client-guidance-for-it-pros-to-protect-against-silicon-based-microarchitectural-and-speculative-execution-side-channel-vulnerabilities-35820a8a-ae13-1299-88cc-357f104f5b11) against silicon-based microarchitectural and speculative execution side-channel vulnerabilities without disabling Hyper-Threading (also known as Simultaneous Multi Threading (SMT)) in Intel processors by executing the following command from an elevated command prompt. | ||||
|   ``` | ||||
|   reg add "HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\Session Manager\Memory Management" /v FeatureSettingsOverride /t REG_DWORD /d 0x00800048 /f  | ||||
|   reg add "HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\Session Manager\Memory Management" /v FeatureSettingsOverrideMask /t REG_DWORD /d 3 /f | ||||
|   reg add "HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows NT\CurrentVersion\Virtualization" /v MinVmVersionForCpuBasedMitigations /t REG_SZ /d "1.0" /f | ||||
|   reg add "HKLM\SOFTWARE\Microsoft\Windows NT\CurrentVersion\Virtualization" /v RetsPredictedFromRsbOnly /t REG_DWORD /d 1 /f | ||||
|   ``` | ||||
|   Enable additional mitigations against silicon-based microarchitectural and speculative execution side-channel vulnerabilities with Hyper-Threading disabled in Intel processors by executing the following command from an elevated command prompt. | ||||
|   ``` | ||||
|   reg add "HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\Session Manager\Memory Management" /v FeatureSettingsOverride /t REG_DWORD /d 0x00802048 /f  | ||||
|   reg add "HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\Session Manager\Memory Management" /v FeatureSettingsOverrideMask /t REG_DWORD /d 3 /f | ||||
|   reg add "HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows NT\CurrentVersion\Virtualization" /v MinVmVersionForCpuBasedMitigations /t REG_SZ /d "1.0" /f | ||||
|   reg add "HKLM\SOFTWARE\Microsoft\Windows NT\CurrentVersion\Virtualization" /v RetsPredictedFromRsbOnly /t REG_DWORD /d 1 /f | ||||
|   ``` | ||||
|   Enable additional mitigations against silicon-based microarchitectural and speculative execution side-channel vulnerabilities in AMD processors by executing the following command from an elevated command prompt. To be fully protected, you might also need to disable Hyper-Threading (also known as Simultaneous Multi Threading (SMT)). | ||||
|   ``` | ||||
|   reg add "HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\Session Manager\Memory Management" /v FeatureSettingsOverride /t REG_DWORD /d 16842760 /f  | ||||
|   reg add "HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\Session Manager\Memory Management" /v FeatureSettingsOverrideMask /t REG_DWORD /d 3 /f | ||||
|   reg add "HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows NT\CurrentVersion\Virtualization" /v MinVmVersionForCpuBasedMitigations /t REG_SZ /d "1.0" /f | ||||
|   reg add "HKLM\SOFTWARE\Microsoft\Windows NT\CurrentVersion\Virtualization" /v RetsPredictedFromRsbOnly /t REG_DWORD /d 1 /f | ||||
|   ``` | ||||
|   Enable additional mitigations against silicon-based microarchitectural and speculative execution side-channel vulnerabilities in ARM processors by executing the following command from an elevated command prompt. To be fully protected, you might also need to disable Hyper-Threading (also known as Simultaneous Multi Threading (SMT)). | ||||
|   ``` | ||||
|   reg add "HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\Session Manager\Memory Management" /v FeatureSettingsOverride /t REG_DWORD /d 64 /f  | ||||
|   reg add "HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\Session Manager\Memory Management" /v FeatureSettingsOverrideMask /t REG_DWORD /d 3 /f | ||||
|   reg add "HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows NT\CurrentVersion\Virtualization" /v MinVmVersionForCpuBasedMitigations /t REG_SZ /d "1.0" /f | ||||
|   reg add "HKLM\SOFTWARE\Microsoft\Windows NT\CurrentVersion\Virtualization" /v RetsPredictedFromRsbOnly /t REG_DWORD /d 1 /f | ||||
|   ``` | ||||
|    | ||||
| ## Privacy Settings | ||||
|  | ||||
| Windows collects [three categories](https://query.prod.cms.rt.microsoft.com/cms/api/am/binary/RW1iLkl) of personal data to send to Microsoft: Windows Diagnostic Data, Account Data, and Windows Required Service Data.  | ||||
|  | ||||
| ### Windows Diagnostic Data | ||||
|  | ||||
| Enable the Group Policy `Computer Configuration\Administrative Templates\Windows Components\Data Collection And Preview Builds\Allow Diagnostic Data` and set it to `Diagnostic data off (not recommended)`. | ||||
|  | ||||
| ### Account Data | ||||
|  | ||||
| Use local accounts instead of online accounts like Microsoft accounts to sign in to your devices and enable the Group Policy `Computer Configuration\Windows Settings\Security Settings\Local Policies\Security Options\Accounts: Block Microsoft accounts` and set it to `Users can’t add Microsoft accounts`. You can still log on apps likw Microsoft Store with Microsoft accounts. If you have logged on apps using a Microsoft account, you can limit its use in Start → Settings → Accounts → Email & accounts → (Your Microsoft Account) → Sign-in Options and select the option to `Apps need to ask me to use this account`. | ||||
|  | ||||
| <details class="warning" markdown> | ||||
| <summary>Warning</summary> | ||||
|  | ||||
| If the Group Policy `Accounts: Block Microsoft accounts` is set to `Users can’t add or log on with Microsoft accounts`, attempting to restore the System in Windows Recovery Environment (Windows RE) will [fail](https://learn.microsoft.com/en-us/windows-hardware/manufacture/desktop/windows-recovery-environment--windows-re--technical-reference?view=windows-11#known-issue) with the error message "You need to sign in as an administrator to continue, but there aren't any administrator accounts on this PC." | ||||
|  | ||||
| </details> | ||||
|  | ||||
| ### Windows Required Service Data | ||||
|  | ||||
| Some Required Service Data is necessary for Windows security and should be retained. | ||||
|  | ||||
| - Uninstall pre-installed apps you won't use in Start → Settings → Apps → Installed Apps and Start → Settings → System → System Components. | ||||
| - Disable all options in Start → Settings → Privacy & Security → Windows Permissions. | ||||
| - Do not join the Windows Insider Program in Start → Settings → Windows Update → Windows Insider Program. | ||||
| - Disable suggestions and recommendations in Start → Settings → Personalization → Start. | ||||
| - Disable the Group Policy `Computer Configuration\Administrative Templates\Windows Components\Search\Allow Cortana`. | ||||
| - Disable the Group Policy `Computer Configuration\Administrative Templates\Windows Components\Search\Allow Cloud Search`. | ||||
| - Disable the Group Policy `Computer Configuration\Administrative Templates\Windows Components\Search\Allow search and Cortana to use location`. | ||||
| - Enable the Group Policy `Computer Configuration\Administrative Templates\Windows Components\Search\Do not allow web search`. | ||||
| - Enable the Group Policy `Computer Configuration\Administrative Templates\Windows Components\Search\Don't search the web or display web results in Search`. | ||||
| - Enable all Group Policy objects under `Computer Configuration\Administrative Templates\Windows Components\Cloud Content`. | ||||
| - Enable the Group Policy `User Configuration\Administrative Templates\Windows Components\Cloud Content\Do not use diagnostic data for tailored experiences`. | ||||
| - Enable the Group Policy `User Configuration\Administrative Templates\Windows Components\Cloud Content\Do not suggest third-party content in Windows spotlight`. | ||||
| - Enable the Group Policy `User Configuration\Administrative Templates\Windows Components\Cloud Content\Turn off cloud optimized content`. | ||||
| - Enable the Group Policy `Computer Configuration\Administrative Templates\Windows Components\Windows Error Reporting\Disable Windows Error Reporting`. | ||||
| - Enable the Group Policy `Computer Configuration\Administrative Templates\Windows Components\Software Protection Platform\Turn off KMS Client Online AVS Validation`. | ||||
| - Disable the Group Policy `Computer Configuration\Administrative Templates\Windows Components\Messaging\Allow Message Service Cloud Sync`. | ||||
| - Execute `reg add "HKEY_CURRENT_USER\SOFTWARE\Microsoft\Messaging" /v CloudServiceSyncEnabled /t REG_DWORD /d 0 /f` from an elevated command prompt. | ||||
| - Execute `reg add "HKEY_LOCAL_MACHINE\Software\Policies\Microsoft\MRT" /v DontReportInfectionInformation /t REG_DWORD /d 1 /f` from an elevated command prompt. | ||||
| - Disable the Group Policy `Computer Configuration\Administrative Templates\Windows Components\Windows Defender Antivirus\Reporting\Configure Watson events`. | ||||
| - In Start → Settings → Apps → Advanced app settings, set `Choose where to get apps` to `Anywhere`. | ||||
| - Enable the Group Policy `Computer Configuration\Administrative Templates\Windows Components\Delivery Optimization\Download Mode` and set it to `Simple (99)`. | ||||
| - Execute `reg add "HKLM\SOFTWARE\Policies\Microsoft\Windows\Windows Feeds" /v "EnableFeeds" /t REG_DWORD /d 0 /f` from an elevated command prompt. | ||||
| - Execute `setx /M DOTNET_CLI_TELEMETRY_OPTOUT 1` from an elevated command prompt. | ||||
| - Execute `setx /M POWERSHELL_TELEMETRY_OPTOUT 1` from an elevated command prompt. | ||||
| - Execute `setx /M MSEDGEDRIVER_TELEMETRY_OPTOUT 1` from an elevated command prompt. | ||||
| - Disable the Group Policy `Computer Configuration\Administrative Templates\Windows Components\Widgets\Allow Widgets`. | ||||
| - If you are using a Input Method Editors (IME), disable the option in Start → Settings → Time & Language → Language & Region → (Your Language) → Language Options → (Your IME) → Keyboard Options → Lexicon and Self-Learning → Try text suggestions from Bing. | ||||
| - You can manage Copilot in Windows by configuring the Group Policy `User Configuration\Administrative Templates\Windows Components\Windows Copilot\Turn off Windows Copilot`. | ||||
| - Enable the Group Policy `Computer Configuration\Administrative Templates\Windows Components\OneDrive\Prevent OneDrive from generating network traffic until the user signs in to OneDrive`. | ||||
|  | ||||
| ## Microsoft Edge | ||||
|  | ||||
| - [Download](https://www.microsoft.com/en-us/edge/business/download) the Microsoft Edge policy and unzip the file. | ||||
| - Copy `MicrosoftEdgePolicyTemplates.cab\MicrosoftEdgePolicyTemplates.zip\windows\admx\msedge.admx` to `C:\Windows\PolicyDefinitions`. Copy `MicrosoftEdgePolicyTemplates.cab\MicrosoftEdgePolicyTemplates.zip\windows\admx\msedge.admx\(Your locale ID)\msedge.adml` to `C:\Windows\PolicyDefinitions\(Your locale ID)`. | ||||
| - You can track security baseline updates using [this](https://techcommunity.microsoft.com/gxcuf89792/rss/board?board.id=Microsoft-Security-Baselines) RSS feed. | ||||
|  | ||||
| ### Microsoft Edge Security | ||||
|  | ||||
| - [Download](https://www.microsoft.com/en-us/download/details.aspx?id=55319) the following files: `Microsoft Edge v117 Security Baseline.zip` and `LGPO.zip`.Unzip both files. In `LGPO\LGPO_30`, copy `LGPO.exe` to `Microsoft Edge v117 Security Baseline\Scripts\Tools`. In `Microsoft Edge v117 Security Baseline\Scripts`, execute the following command from an elevated command prompt: | ||||
|   ``` | ||||
|   Set-ExecutionPolicy -Scope Process Unrestricted | ||||
|   .\Baseline-LocalInstall.ps1 | ||||
|   ``` | ||||
| - Microsoft Edge automatically updates itself. You can also update it manually in `edge://settings/help`. | ||||
| - Enable the option(s) `Microsoft Defender SmartScreen` in `edge://settings/privacy`. | ||||
| - Enable the option(s) `Block potentially unwanted apps` in `edge://settings/privacy`. | ||||
| - Enable the option(s) `Website typo protection` in `edge://settings/privacy`. | ||||
| - Enable the option(s) `Enhance your security on the web` in `edge://settings/privacy` and set it to `Strict`. | ||||
| - Enable the option(s) `Allow extensions from other stores` in `edge://extensions/`. Prioritize installing extensions from Chrome Web Store, as Chrome Web Store more aggressively uses Manifest V3. | ||||
| - Enable the Group Policy `Computer Configuration\Administrative Templates\Microsoft Edge\Configure browser process code integrity guard setting` and set it to `Enable code integrity guard enforcement in the browser process`. | ||||
| - Enable the Group Policy `Computer Configuration\Administrative Templates\Microsoft Edge\Enable online OCSP/CRL checks`. | ||||
| - Enable the Group Policy `Computer Configuration\Administrative Templates\Microsoft Edge\Enable the network service sandbox`. | ||||
| - Enable the Group Policy `Computer Configuration\Administrative Templates\Microsoft Edge\Restrict exposure of local IP address by WebRTC` and set it to `Use TCP unless proxy server supports UDP`. | ||||
| - Enable the Group Policy `Computer Configuration\Administrative Templates\Microsoft Edge\Configure Automatic HTTPS` and set it to `All navigations delivered over HTTP are switched to HTTPS`. | ||||
| - Enable the Group Policy `Computer Configuration\Administrative Templates\Microsoft Edge\Control the mode of DNS-over-HTTPS` and set it to `Enable DNS-over-HTTPS without insecure fallback`. Configure the Group Policy `Computer Configuration\Administrative Templates\Microsoft Edge\Specify URI template of desired DNS-over-HTTPS resolver` according to your needs. | ||||
|  | ||||
| ### Microsoft Edge Privacy | ||||
|  | ||||
| For diagnostic data, enable the Group Policy `Computer Configuration\Administrative Templates\Microsoft Edge\Send required and optional diagnostic data about browser usage` and set the option to `off`. | ||||
|  | ||||
| For account data, use local profiles instead of online accounts like Microsoft accounts to sign in to Microsoft Edge. Enable the Group Policy `Computer Configuration\Administrative Templates\Microsoft Edge\Browser sign-in settings` and set the option to `Disable browser sign-in`. Then disable the Group Policy `Computer Configuration\Administrative Templates\Microsoft Edge\Configure whether a user always has a default profile automatically signed in with their work or school account`. | ||||
|  | ||||
| For required service data: | ||||
|  | ||||
| - Disable the option(s) in `edge://settings/profiles/rewards`. | ||||
| - Disable the option(s) in `edge://settings/profiles/multiProfileSettings`. | ||||
| - Disable the option(s) in `edge://settings/profiles/localBrowserDataShare`. | ||||
| - Disable the option(s) in `edge://wallet/settings`. | ||||
| - Enable the option(s) `Tracking Prevention` in `edge://settings/privacy` and set the option to `Strict`. | ||||
| - Enable the option(s) in `edge://settings/clearBrowsingDataOnClose`. | ||||
| - Enable the option(s) `Send "Do Not Track" requests` in `edge://settings/privacy`. | ||||
| - Disable the option(s) `Allow sites to check if you have payment methods saved` in `edge://settings/privacy`. | ||||
| - Disable the option(s) `Allow sites to check if you have payment methods saved` in `edge://settings/privacy`. | ||||
| - Disable the option(s) `Help improve Microsoft products by sending the results from searches on the web` in `edge://settings/privacy`. | ||||
| - Disable the option(s) `Allow Microsoft to save your browsing activity including history, usage, favorites, web content, and other browsing data to personalize Microsoft Edge and Microsoft services like ads, search, shopping and news.` in `edge://settings/privacy`. | ||||
| - Disable all option(s) under the `Services` section in `edge://settings/privacy`. | ||||
| - Disable the option(s) `Show me search and site suggestions using my typed characters` in `edge://settings/searchFilters`. | ||||
| - Disable the option(s) `Show me suggestions from history, favorites and other data on this device using my typed characters` in `edge://settings/searchFilters`. | ||||
| - Disable the option(s) `Personalize my top sites in customize sidebar` in `edge://settings/sidebar`. | ||||
| - Disable the option(s) `Allow Microsoft to access page content` and `Show shopping notifications` in `edge://settings/sidebar/appSettings?hubApp=cd4688a9-e888-48ea-ad81-76193d56b1be`. | ||||
| - Disable the option(s) `Allow access to page URLs` in `edge://settings/sidebar/appSettings?hubApp=96defd79-4015-4a32-bd09-794ff72183ef`. | ||||
| - Disable the option(s) `Preload your new tab page for a faster experience` in `edge://settings/startHomeNTP`. | ||||
| - Configure the option(s) `Customize your new tab page layout and content` in `edge://settings/startHomeNTP` according to your needs. | ||||
| - Enable the option(s) `Block third-party cookies` in `edge://settings/content/cookies`. | ||||
| - Disable the option(s) `Preload pages for faster browsing and searching` in `edge://settings/content/cookies`. | ||||
| - Disable the option(s) `Use text prediction` in `edge://settings/languages`. | ||||
| - Disable the option(s) `Enable grammar and spellcheck assistance` or enable it with `Basic` in `edge://settings/languages`. | ||||
| - Configure the option(s) `Share additional operating system region` to `Never` in `edge://settings/languages`. | ||||
| - Disable the option(s) `Get image descriptions from Microsoft for screen readers` in `edge://settings/accessibility`. | ||||
| - Disable the option(s) `Allow identifiers for protected content (computer restart may be required)` in `edge://settings/content/protectedContent`. | ||||
| - Configure `edge://flags/#edge-widevine-drm` according to your needs. | ||||
| - Disable the Group Policy `Computer Configuration\Administrative Templates\Microsoft Edge\Enables default browser settings campaigns`. | ||||
| - Disable the Group Policy `Computer Configuration\Administrative Templates\Microsoft Edge\Edge 3P SERP Telemetry Enabled`. | ||||
| - Enable the Group Policy `Computer Configuration\Administrative Templates\Microsoft Edge\Enable network prediction` and set it to `Don’t predict network actions on any network connection`. | ||||
| - Enable the Group Policy `Computer Configuration\Administrative Templates\Microsoft Edge\Secure mode and Certificate-based Digital Signature validation in native PDF reader`. | ||||
| - Disable the Group Policy `Computer Configuration\Administrative Templates\Microsoft Edge\Content settings\Choose whether users can receive customized background images and text, suggestions, notifications, and tips for Microsoft services`. | ||||
| - Enable the Group Policy `Computer Configuration\Administrative Templates\Microsoft Edge\Configure InPrivate mode availability` and set it to `Forced`. | ||||
|  | ||||
|   <details class="warning" markdown> | ||||
|   <summary>Warning</summary> | ||||
|  | ||||
|   Setting ```Configure InPrivate mode availability``` to ```Forced``` will prevent you from accessing `edge://settings`. | ||||
|  | ||||
|   </details> | ||||
|  | ||||
| - If you are using others’ PC, use Guest mode in Start → Microsoft Edge → Personal Profile icon → Other Profiles → Browse as Guest. | ||||
| - You can manage Copilot in Windows by configuring the Group Policy `Computer Configuration\Administrative Templates\Microsoft Edge\Show Hubs Sidebar`. | ||||
|  | ||||
| ## Office | ||||
|  | ||||
| - The advice in this guide does not apply to Office downloaded from the Microsoft Store. | ||||
| - [Download](https://www.microsoft.com/en-us/download/details.aspx?id=49030) the corresponding Office policy and execute it to extract the files. | ||||
| - Copy `(Extracted Files)\admx\(Your Office Apps).admx` to `C:\Windows\PolicyDefinitions`. Copy `(Extracted Files)\admx\(Your locale ID)\(Your Office Apps).adml` to `C:\Windows\PolicyDefinitions\(Your locale ID)`. | ||||
| - You can track security baseline updates using [this](https://techcommunity.microsoft.com/gxcuf89792/rss/board?board.id=Microsoft-Security-Baselines) RSS feed. | ||||
|  | ||||
| <details class="note" markdown> | ||||
| <summary>Install and Activate Office 2021</summary> | ||||
|  | ||||
| You can buy and download [Office Home & Student 2021](https://go.microsoft.com/fwlink/?linkid=2022066), [Office Home & Business 2021](https://go.microsoft.com/fwlink/?linkid=2022187) or [Office Professional 2021](https://go.microsoft.com/fwlink/?linkid=2022071) online. | ||||
|  | ||||
| To install Office LTSC 2021, download the [Office Deployment Tool](https://www.microsoft.com/en-us/download/details.aspx?id=49117) and execute it to extract the files. Create and download a configuration file using the [Office Customization Tool](https://config.office.com/deploymentsettings). Copy `your-created-config-file.xml` to `(Extracted Files Folder)`. In `(Extracted Files Folder)`, execute the following command from an elevated command prompt: | ||||
|  | ||||
| ``` | ||||
| setup /download your-created-config-file.xml | ||||
| ``` | ||||
|  | ||||
| For Key Management Service (KMS) activation, execute the following command from an elevated command prompt: | ||||
|  | ||||
| ``` | ||||
| cd "c:\Program Files\Microsoft Office\Office16" | ||||
| cscript ospp.vbs /sethst:your.kms.server.here | ||||
| cscript ospp.vbs /act | ||||
| ``` | ||||
|  | ||||
| For Multiple Activation Key (MAK) activation, execute the following command from an elevated command prompt: | ||||
|  | ||||
| ``` | ||||
| cd "c:\Program Files\Microsoft Office\Office16" | ||||
| cscript ospp.vbs /inpkey:input-your-mak-key-here | ||||
| cscript ospp.vbs /act | ||||
| ``` | ||||
|  | ||||
| </details> | ||||
|  | ||||
| ### Office Security | ||||
|  | ||||
| - [Download](https://www.microsoft.com/en-us/download/details.aspx?id=55319) the following files: `Microsoft 365 Apps for Enterprise 2306.zip` and `LGPO.zip`.Unzip both files. In `LGPO\LGPO_30`, copy `LGPO.exe` to `Microsoft 365 Apps for Enterprise 2306\Scripts\Tools`. In `Microsoft 365 Apps for Enterprise 2306\Scripts`, execute the following command from an elevated command prompt: | ||||
|    | ||||
|   ``` | ||||
|   Set-ExecutionPolicy -Scope Process Unrestricted | ||||
|   .\Baseline-LocalInstall.ps1 | ||||
|   ``` | ||||
|    | ||||
| - Office automatically updates itself. You can also update it manually in Start → (Your Office Apps) → File → Account → Update Options. | ||||
|    | ||||
| ### Office Privacy | ||||
|  | ||||
| For diagnostic data, enable the Group Policy `User Configuration\Administrative Templates\Microsoft Office 2016\Privacy\Trust Center\Configure the level of client software diagnostic data sent by Office to Microsoft` and set the option to `Neither`. | ||||
|  | ||||
| For account data, enable the Group Policy `User Configuration\Administrative Templates\Microsoft Office 2016\Miscellaneous\Block signing into Office`. | ||||
|  | ||||
| <details class="info" markdown> | ||||
| <summary>Microsoft 365</summary> | ||||
|  | ||||
| You cannot disable the subscription version of Office, Microsoft 365. | ||||
|  | ||||
| </details> | ||||
|  | ||||
| For required service data, disable the Group Policy `User Configuration\Administrative Templates\Microsoft Office 2016\Privacy\Trust Center\Allow the use of connected experiences in Office` and `User Configuration\Administrative Templates\Microsoft Office 2016\Privacy\Trust Center\Enable Customer Experience Improvement Program`. | ||||
							
								
								
									
										2499
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										2499
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -1,8 +0,0 @@ | ||||
| { | ||||
|   "devDependencies": { | ||||
|     "@netlify/plugin-lighthouse": "^5.0.0" | ||||
|   }, | ||||
|   "engines": { | ||||
|     "node" : ">=18.0.0 <19.0.0" | ||||
|   } | ||||
| } | ||||
		Reference in New Issue
	
	Block a user