Compare commits
	
		
			3 Commits
		
	
	
		
			reuse-lice
			...
			pr/1659
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 0ad0f31086 | |||
|   | 778cd6c22b | ||
|   | 10e58c21ff | 
| @@ -109,6 +109,11 @@ nav: | ||||
|       - 'os/android-overview.md' | ||||
|       - 'os/linux-overview.md' | ||||
|       - 'os/qubes-overview.md' | ||||
|       - Windows Overview: | ||||
|         - 'os/windows/index.md' | ||||
|         - 'os/windows/hardening.md' | ||||
|         - 'os/windows/privacy.md' | ||||
|         - 'os/windows/sandboxing.md' | ||||
|     - Advanced Topics: | ||||
|       - 'advanced/dns-overview.md' | ||||
|       - 'advanced/tor-overview.md' | ||||
|   | ||||
| @@ -109,6 +109,11 @@ nav: | ||||
|       - 'os/android-overview.md' | ||||
|       - 'os/linux-overview.md' | ||||
|       - 'os/qubes-overview.md' | ||||
|       - Windows Overview: | ||||
|         - 'os/windows/index.md' | ||||
|         - 'os/windows/hardening.md' | ||||
|         - 'os/windows/privacy.md' | ||||
|         - 'os/windows/sandboxing.md' | ||||
|     - "Sujets avancés": | ||||
|       - 'advanced/dns-overview.md' | ||||
|       - 'advanced/tor-overview.md' | ||||
|   | ||||
| @@ -113,6 +113,11 @@ nav: | ||||
|       - 'os/android-overview.md' | ||||
|       - 'os/linux-overview.md' | ||||
|       - 'os/qubes-overview.md' | ||||
|       - Windows Overview: | ||||
|         - 'os/windows/index.md' | ||||
|         - 'os/windows/hardening.md' | ||||
|         - 'os/windows/privacy.md' | ||||
|         - 'os/windows/sandboxing.md' | ||||
|     - "נושאים מתקדמים": | ||||
|       - 'advanced/dns-overview.md' | ||||
|       - 'advanced/tor-overview.md' | ||||
|   | ||||
| @@ -109,6 +109,11 @@ nav: | ||||
|       - 'os/android-overview.md' | ||||
|       - 'os/linux-overview.md' | ||||
|       - 'os/qubes-overview.md' | ||||
|       - Windows Overview: | ||||
|         - 'os/windows/index.md' | ||||
|         - 'os/windows/hardening.md' | ||||
|         - 'os/windows/privacy.md' | ||||
|         - 'os/windows/sandboxing.md' | ||||
|     - Gevorderde onderwerpen: | ||||
|       - 'advanced/dns-overview.md' | ||||
|       - 'advanced/tor-overview.md' | ||||
|   | ||||
| @@ -98,6 +98,11 @@ nav: | ||||
|       - 'os/android-overview.md' | ||||
|       - 'os/linux-overview.md' | ||||
|       - 'os/qubes-overview.md' | ||||
|       - Windows Overview: | ||||
|         - 'os/windows/index.md' | ||||
|         - 'os/windows/hardening.md' | ||||
|         - 'os/windows/privacy.md' | ||||
|         - 'os/windows/sandboxing.md' | ||||
|     - Advanced Topics: | ||||
|       - 'advanced/dns-overview.md' | ||||
|       - 'advanced/tor-overview.md' | ||||
|   | ||||
| After Width: | Height: | Size: 79 KiB | 
| After Width: | Height: | Size: 85 KiB | 
							
								
								
									
										
											BIN
										
									
								
								docs/assets/img/windows/Bitlocker Group Policies/TPM+PIN.webp
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 116 KiB | 
| After Width: | Height: | Size: 56 KiB | 
| After Width: | Height: | Size: 56 KiB | 
| After Width: | Height: | Size: 111 KiB | 
| After Width: | Height: | Size: 82 KiB | 
| After Width: | Height: | Size: 62 KiB | 
| After Width: | Height: | Size: 82 KiB | 
							
								
								
									
										
											BIN
										
									
								
								docs/assets/img/windows/EFS.gif
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 1.7 MiB | 
							
								
								
									
										
											BIN
										
									
								
								docs/assets/img/windows/UWP-in-MS-Store.webp
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 69 KiB | 
							
								
								
									
										
											BIN
										
									
								
								docs/assets/img/windows/Win32-in-MS-Store.webp
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 66 KiB | 
							
								
								
									
										
											BIN
										
									
								
								docs/assets/img/windows/autoplay.webp
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 13 KiB | 
							
								
								
									
										
											BIN
										
									
								
								docs/assets/img/windows/disable-telemetry.webp
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 109 KiB | 
							
								
								
									
										
											BIN
										
									
								
								docs/assets/img/windows/drive-restriction.webp
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 106 KiB | 
							
								
								
									
										
											BIN
										
									
								
								docs/assets/img/windows/lock-screen-notifications.webp
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 17 KiB | 
							
								
								
									
										
											BIN
										
									
								
								docs/assets/img/windows/online-speech.webp
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 27 KiB | 
							
								
								
									
										
											BIN
										
									
								
								docs/assets/img/windows/privacy-settings.webp
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 42 KiB | 
							
								
								
									
										
											BIN
										
									
								
								docs/assets/img/windows/signin-one-app.webp
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 33 KiB | 
							
								
								
									
										
											BIN
										
									
								
								docs/assets/img/windows/user-account.webp
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 33 KiB | 
							
								
								
									
										
											BIN
										
									
								
								docs/assets/img/windows/voice-activation.webp
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 15 KiB | 
							
								
								
									
										227
									
								
								docs/os/windows/hardening.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,227 @@ | ||||
| --- | ||||
| title: System Hardening | ||||
| icon: material/monitor-lock | ||||
| --- | ||||
|  | ||||
| ## Setting up Windows after Installation | ||||
|  | ||||
| If you wish to limit the amount of data Microsoft obtains from your device, an [offline/local account](https://answers.microsoft.com/en-us/windows/forum/all/how-to-create-a-local-or-offline-account-in/95097c32-40c4-48c0-8f3b-3bcb67afaf7c) is **recommended**.  | ||||
|  | ||||
|  | ||||
|  | ||||
| !!! note | ||||
|     Microsoft is pushing users to use Microsoft accounts for other editions except Education and Enterprise after installation.  | ||||
|  | ||||
|     So, You could also follow the guide by [ghacks.net](https://www.ghacks.net/2022/05/13/how-to-bypass-the-microsoft-account-requirement-during-windows-setup/) to bypass the Microsoft account requirement during setup and use Local account. | ||||
|  | ||||
| While setting up, it is recommended to use a generic name such as `user` and `host` and avoid identifying terms such as your name or operating system. This can make it more difficult for privileged `Win32` apps or attackers to discern your identity. | ||||
|  | ||||
| For security, it's recommended to set up Windows Hello on all of your accounts because it uses the trusted platform module (TPM) if applicable, which protects against brute-force attacks; see the documentation: [How Windows Uses the TPM](https://docs.microsoft.com/en-us/windows/security/information-protection/tpm/how-windows-uses-the-tpm#windows-hello-for-business) | ||||
|  | ||||
| - [ ] Toggle off all privacy related settings as shown in the image: | ||||
|  | ||||
|  | ||||
| ## Encrypting the Drive | ||||
|  | ||||
| After you have installed Windows, turn on full disk encryption (FDE) using BitLocker via the Control Panel.  | ||||
|  | ||||
| !!! info "Choosing the Way to Encrypt" | ||||
|     It is recommended to use only the Control Panel because if you go to encrypt via settings app, Microsoft named it as `Device Encryption` and designed it in a way that the encryption keys for BitLocker would be stored on Microsoft's server which is attached to your Microsoft account. This can be dangerous to your privacy and security as anyone who gains access to your account, as could an attacker if they were able to gain access to Microsoft's servers or any Law Enforcement could by a Gag order.  | ||||
|  | ||||
| The best way is to go to the Control Panel by searching for it in the Start Menu or from the context menu (right-click) in File Explorer and set it up for all of the drives that you have. | ||||
|  | ||||
|  | ||||
|  | ||||
| Bitlocker is suggested because of the native implementation by the OS and along with the usage of hardware to be resistant against encryption flaws. | ||||
|  | ||||
| ### Security policies for Bitlocker | ||||
|  | ||||
| Enable the Following group policies before you start encrypting your drives. | ||||
|  | ||||
| !!! tip | ||||
|     To go to it, search **Group Policy** in the **Windows Search Bar** and press **Enter** or type `gpedit.msc` in ++win+r++. Then, proceed as mentioned below. | ||||
|  | ||||
| General Policies : | ||||
|  | ||||
| Go to `Computer Configuration` > `Administrative Templates` > `Windows Components` > `Bitlocker Drive Encryption` | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
| For OS drives :  | ||||
|  | ||||
| Go to `Computer Configuration` > `Administrative Templates` > `Windows Components` > `Bitlocker Drive Encryption` > `Operating System Drives` | ||||
|  | ||||
| Enable Group policies as in the images below <!--(Check images side by side)--> : | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
| For Fixed Drives : | ||||
|  | ||||
| Go to `Computer Configuration` > `Administrative Templates` > `Windows Components` > `Bitlocker Drive Encryption` > `Fixed Data Drives` > `Enforce drive encryption type on fixed data drives` | ||||
|  | ||||
|  | ||||
|  | ||||
| These policies ensure that your drives are encrypted with `XTS-AES-256` Bit encryption, **fully**. | ||||
|  | ||||
| ### Setting up Pre-boot Authentication | ||||
|  | ||||
| !!! warning "Update your TPM" | ||||
|     Before enabling Bitlocker in your device,It is strongly recommended to update your TPM chip by downloading package only from **OEM** Websites. | ||||
|  | ||||
| As you are using Windows 11, TPM is used to encrypt and decrypt the drive but it is susceptible to [cold boot attacks](https://blog.elcomsoft.com/2021/01/understanding-bitlocker-tpm-protection/). So, it is recommended to use TPM + PIN to protect the drives | ||||
|  | ||||
| After enabling all the group policies above, Go to Control panel and click on Add PIN. It can be alphanumeric if you had enabled the above policies. | ||||
|  | ||||
| You can check if it's enabled by typing `manage-bde -status`. It will normally show in **Key Protectors**: **Numerical Password** (it's the recovery key) and **TPM And PIN**. | ||||
|  | ||||
| ??? abstract "Disabling pre-boot Authentication (Not Recommended)" | ||||
|      | ||||
|     - open a **terminal** as an **administrator** and type this command `manage-bde -protectors -add c: -TPM`.  | ||||
|     - You can again check if it worked by typing `manage-bde -status c:` and it will show you **Numerical Password** and **TPM** | ||||
|  | ||||
| !!! info  | ||||
|     The above Group Policy configuration tells the TPM to release the encryption keys after entering PIN instead of releasing it on boot automatically. | ||||
|  | ||||
|     Doing this will set a double password. So, you enter the PIN to release the encryption keys from TPM & boot Windows and another credential to unlock your user account. | ||||
|  | ||||
|     The pre-boot PIN not only protects the OS drive but also other fixed drives used just for storage if bitlocker is enabled for that drive also. | ||||
|  | ||||
| When you do this, the encryption keys of your drive are only unlocked once you enter the PIN, and the decryption happens after. If you forget or lose the PIN, you won't be able to access your drives and OS anymore, and the only way to recover is using the Recovery Key provided during the initial setup of BitLocker. **Make sure you store it in a safe place**, such as a password manager, and keep backups of your Recovery Key or even use an encrypted USB drive. | ||||
|  | ||||
| The preboot authentication is recommend to avoid data being accessed by removal of user Account passwords by methods like this - https://youtu.be/0gOZoroPNuA and access data even though Bitlocker is enabled and managed by TPM | ||||
|  | ||||
| But when you use TPM + Startup PIN, nobody can restart to load the shell and bypass password. Because you need to enter your PIN to go to the Advanced Startup settings as in the video. | ||||
|  | ||||
| Enabling or not-enabling is up to the user's threat model. | ||||
|  | ||||
| If it's a personal device, Startup PIN + TPM is recommended.  | ||||
| If a family computer, Normal Bitlocker (Managed by TPM) for OS drive is recommended. | ||||
|  | ||||
| It is recommended to encrypt the OS drive at the least. Encrypting secondary drives either via Bitlocker or other encryption tools such as Veracrypt is upto the user's threat model. | ||||
|  | ||||
| ## Creation of User Account and usage | ||||
|  | ||||
| - By Default Windows gives `administrator` access to the user account. Create another `standard` user account to reduce the attack surface enormously as most vulnerabilities today come from the fact that the user is always in `administrator` mode. In addition, you shouldn't use the same password for standard and administrator account. | ||||
|  | ||||
| - Don't use admin account for any of your personal tasks! | ||||
|  | ||||
| - Just restrict it to the standard account created. | ||||
|  | ||||
| - Set [UAC](https://docs.microsoft.com/en-us/windows/security/identity-protection/user-account-control/user-account-control-security-policy-settings) settings to the [Highest Privilege](https://support.microsoft.com/en-us/windows/about-user-account-control-settings-d5b2046b-dcb8-54eb-f732-059f321afe18). | ||||
|      | ||||
| - Only use your account for you, if someone needs to use your computer **ALWAYS** create another standard account, even if it's for a one-time use, even if it's your family or someone you trust. This person can plug a malicious USB, can connect to malicious Wi-Fi network, download infectious files, etc... without you knowing about it. | ||||
|  | ||||
| - You might be afraid that the user accessing your device via another User account can access your Internal drive and access critical files violating your privacy. Refer, [Privacy page](windows/privacy/#restrict-access-to-data-drives) on How to restrict access to certain drives only or use EFS on a per-file basis. You can read more about EFS on [Privacy page](privacy.md). | ||||
|  | ||||
| !!! tip | ||||
|     You should ALWAYS do the quick shortcut ++win+l++ to lock your device when you are away to prevent unauthorized access. | ||||
|  | ||||
| - If you don't like managing a standard account, then enforce authentication for Administrator accounts too like Standard ones by following the guide by [Wikihow](https://www.wikihow.tech/Require-UAC-Passwords-on-Administrator-Accounts) | ||||
|     - This way, Even administrators need to use Password to approve processes instead of just clicking `Yes` or `No`. | ||||
|  | ||||
| ## Securing the Boot chain | ||||
|  | ||||
| - In your BIOS/UEFI settings, disable the booting of USB devices | ||||
| - Add a password to your BIOS/UEFI settings which restricts anyone from changing them. | ||||
|  | ||||
| ### Enabling Secure Boot | ||||
|  | ||||
| - Windows 11 secures its bootloader by default by using Secure boot with the usage of TPM. | ||||
|  | ||||
| - Windows 10, on the other hand, doesn't come with Secure boot enabled by default except for new devices.  | ||||
|  | ||||
| To enable Secure Boot from the PC BIOS menu. Follow this Step-by-Step Instructions by visiting this [documentation](https://docs.microsoft.com/en-us/windows-hardware/manufacture/desktop/disabling-secure-boot?view=windows-11#re-enable-secure-boot). | ||||
|  | ||||
| Visit: [https://docs.microsoft.com/en-us/mem/intune/user-help/you-need-to-enable-secure-boot-windows#check-secure-boot-status](https://docs.microsoft.com/en-us/mem/intune/user-help/you-need-to-enable-secure-boot-windows#check-secure-boot-status) on how to verify if enabled after enabling secure boot. | ||||
|  | ||||
| ### Firmware Protection | ||||
|  | ||||
| As there are thousands of PC vendors that produce many models with different UEFI BIOS versions, there becomes an incredibly large number of SRTM measurements upon bootup. Two techniques exist to establish trust here—either maintain a list of known 'bad' SRTM measurements (also known as a blocklist), or a list of known 'good' SRTM measurements (also known as an allowlist). | ||||
|  | ||||
| **System Guard** lets the system freely boot into untrusted code initially, but shortly after launches the system into a trusted state by taking control of all CPUs and forcing them down a well-known and measured code path. This has the benefit of allowing untrusted early UEFI code to boot the system, but then being able to securely transition into a trusted and measured state. | ||||
|  | ||||
| - [x] Enable [System Guard](https://docs.microsoft.com/en-us/windows/security/threat-protection/windows-defender-system-guard/how-hardware-based-root-of-trust-helps-protect-windows) by following the instructions of [Microsoft Docs](https://docs.microsoft.com/en-us/windows/security/threat-protection/windows-defender-system-guard/system-guard-secure-launch-and-smm-protection) to secure the boot chain. | ||||
|  | ||||
| You can also know how to check if it is enabled or not in the guide. | ||||
|  | ||||
| !!! note | ||||
|     System Guard is mostly available on Windows Secured-Core PCs not on regular consumer devices. So, Before enabling it check the requirements of your Device. | ||||
| ## Protection against Malware and Viruses | ||||
|  | ||||
| - Just use the built-in Windows Defender Security to protect against threats and stick to it. Don't use any other Antivirus or Anti-Malware software [as it can weaken your security and your privacy](https://wonderfall.space/windows-hardening/#microsoft-defender-antivirus). | ||||
|  | ||||
| - [x] **Enable** [Windows Defender in a Sandbox](https://www.microsoft.com/security/blog/2018/10/26/windows-defender-antivirus-can-now-run-in-a-sandbox/) by launching a **terminal** as an **administrator** and copy/paste this command ```setx /M MP_FORCE_USE_SANDBOX 1```. Restart your device and check if there's a process called **MsMpEngCP.exe** by typing `tasklist` in the terminal to verify. | ||||
|      | ||||
| - [ ] Disable Autoplay for devices so that malware hidden in USB don't execute on plugging in | ||||
|      | ||||
| - [x] Enable [Controlled Folder Access](https://docs.microsoft.com/en-us/microsoft-365/security/defender-endpoint/enable-controlled-folders) in Windows defender settings. So, The Important folders you listed for protection doesn't get attacked or held hostage in case of a ransomware attack and also stops apps from accessing your important folders. This could also be used as a firewall for the filesystem such as Choosing the drives in the protected ones. And allowing each app when it request access to your device. | ||||
|  | ||||
| - [x] Enable [Microsoft Defender Application Guard](https://docs.microsoft.com/en-us/windows/security/threat-protection/microsoft-defender-application-guard/md-app-guard-overview). After installing by going to "[Turn Windows Features on or off](https://docs.microsoft.com/en-us/windows/security/threat-protection/microsoft-defender-application-guard/install-md-app-guard)" you can enable it. This runs Microsoft Edge in an Isolated Hyper-V container preventing unknown Malware from damaging the system. | ||||
|  | ||||
| !!! warning | ||||
|     When you use Microsoft Defender Application Guard it bypasses the VPN you are using as when you use WDAG is launching the application in what is essentially a virtual machine, so it bypasses the host, where the VPN is connected.  | ||||
|  | ||||
| - [x] Enable [Memory Integrity](https://support.microsoft.com/en-us/windows/core-isolation-e30ed737-17d8-42f3-a2a9-87521df09b78) (also called Hypervisor-Protected Code Integrity) in Windows Defender settings which will run important system process isolated in an environment that cannot be attacked by viruses & malware. | ||||
|  | ||||
| - [x] Enable `Display File Extensions` as most problems start here. | ||||
|      | ||||
|     ??? example  "Enabling file extension" | ||||
|         On standard Windows settings, Malware can hide itself if the filename is like: `Secure-File.txt.exe` | ||||
|  | ||||
|         What you see? A file named `Secure-File.txt` | ||||
|  | ||||
|         Of course the attacker can add a different icon to the file, so it looks like you open the file type extension you think. | ||||
|  | ||||
|         And if you open it, the Malware start's. | ||||
|  | ||||
|         Just Open the File Explorer's settings and change it to show File Extensions by clicking on `View` > `Show` or by configuring via [Registry Editor](https://github.com/beerisgood/Windows11_Hardening/blob/master/always%20display%20file%20typ%20extension) | ||||
|  | ||||
| ## Apps | ||||
|  | ||||
| - Avoid any types of Cleaning software at all cost. As Microsoft is working on its own implementation specfically designed for windows. | ||||
| - To Install apps, using the `winget` (Windows Package manager). More details in [Sandboxing page](/windows/sandboxing/#using-winget-to-install-sofwaret) | ||||
| ## Security Improvements | ||||
|  | ||||
| - Use [PeaZip](https://peazip.github.io/) archiver instead of 7-zip as it disables [Mark of the Web(MoW)](https://nolongerset.com/mark-of-the-web-details/) [support by default](https://github.com/nmantani/archiver-MOTW-support-comparison#*2) leading to execution of malicious instantly after extracting. | ||||
|  | ||||
| - Using MS edge or brave over Firefox. Edge is recommended with MDAG mode for secure browsing if security is your priority. Brave is recommeded if content blocking is important for you (Brave shields) | ||||
|  | ||||
| - [Check](https://learn.microsoft.com/en-us/windows/security/information-protection/kernel-dma-protection-for-thunderbolt#how-to-check-if-kernel-dma-protection-is-enabled) if Kernel DMA protections is turned on. | ||||
|  | ||||
| - Use [Winget](/windows/sandboxing/#using-winget-to-install-sofware) tool to remove Bloatware instead of third party apps. | ||||
|  | ||||
| - [x] Block all incoming connections in Windows firewall. | ||||
|     - Go to `Firewall & Network Protection` in Windows defender security. | ||||
|     - Go to `Domain`, `Private` and `Public` network settings | ||||
|     - Scroll and check the box under **Incoming Connections** | ||||
|  | ||||
|     !!! warning "A note regarding screen casting" | ||||
|         If you try to cast your screen to another device or cast another device screen to your device via Wireless display (Optional feature). You won't be able to connect the devices. As we have blocked Incoming connections. Miracast (Wireless casting) requires incoming connection to send data back and forth to show the screen on other or vice versa. | ||||
|  | ||||
|         If you want to cast, then disable incoming connections in public network and cast your device and block connection again. | ||||
|  | ||||
|         There is no problem if you use normal Projection via cable. | ||||
| ## Keeping your device up-to-date | ||||
|  | ||||
| You should keep your Windows Device up-to-date by enabling automatic updates. It is recommended to do so to keep your device with latest security fixes and new features. | ||||
|      | ||||
| To get information about the latest updates, you can look at the [Windows Release Information](https://docs.microsoft.com/en-us/windows/release-health/windows11-release-information). | ||||
|  | ||||
| It is recommended to stick to driver updates provided via Optional Updates, as they are thoroughly vetted by Microsoft for the stability of your device, and **do not rely on third-party apps for driver updates**. This way, you get the latest updates and security patches for your drivers along with firmware updates as long as your device is supported by the OEM. | ||||
|  | ||||
| Some Hardware vendors like Nvidia, Intel has their own updater tool which will provide latest drivers. | ||||
|  | ||||
| It is recommended to rather rely on Windows updates or first-party apps. | ||||
|  | ||||
| **Credits** : The page is mostly made based on the recommendations of Windows Hardening Guide by [beerisgood](https://github.com/beerisgood/Windows11_Hardening) | ||||
|  | ||||
| *[TPM]: Trusted Platform Module | ||||
| *[FDE]: Full Disk Encryption | ||||
| *[UAC]: User Account Control | ||||
| *[WDAG]: Windows Defender Application Guard | ||||
| *[SRTM]: Static Root-of-Trust Measurement | ||||
							
								
								
									
										87
									
								
								docs/os/windows/index.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,87 @@ | ||||
| --- | ||||
| title: Windows Overview | ||||
| icon: material/microsoft-windows | ||||
| --- | ||||
|  | ||||
| ## Windows | ||||
|  | ||||
| Windows is a proprietary operating system created by Microsoft Inc. in 1985. It is primarily focused on personal computing and is now the most popular desktop OS, used by about [75%](https://gs.statcounter.com/os-market-share/desktop/worldwide) of all desktop users. However, it has its own privacy and security issues. | ||||
|  | ||||
| ## Issues present in Windows | ||||
|  | ||||
| Over the years, Microsoft has demonstrated a lot of privacy-invasive behaviour with their software and services. They have continually taken advantage of the fact that Windows is the most wide-used desktop OS, and that most people don't change the default settings, in order to collect users' personal information. | ||||
|  | ||||
| Windows 10 was [criticized](https://www.theguardian.com/technology/2015/jul/31/windows-10-microsoft-faces-criticism-over-privacy-default-settings) for having default settings that sent a lot of data and telemetry back to Microsoft, including: | ||||
|  | ||||
| !!! quote "[Criticism of Microsoft - Wikipedia](https://en.wikipedia.org/wiki/Criticism_of_Microsoft#Telemetry_and_data_collection)" | ||||
|     User's contacts and calendar events, location data and history, "telemetry" (diagnostics data) ... and "advertising ID", as well as further data when the Cortana assistant is enabled. | ||||
|  | ||||
| At launch, telemetry could not be disabled in non-enterprise editions of Windows 10. Only after [criticism](https://www.theverge.com/2016/7/21/12246266/france-microsoft-privacy-windows-10-cnil) from the France data protection commission, the [Electronic Frontier Foundation](https://www.eff.org/deeplinks/2016/08/windows-10-microsoft-blatantly-disregards-user-choice-and-privacy-deep-dive) and the [European Union](https://www.reuters.com/article/us-microsoft-dataprotection-eu-idUSKBN15Z1UI), Microsoft changed the way they collect telemetry, allowing users to choose between "Basic" (now renamed as `Required`) and "Full", with "Basic" mode collecting [much less telemetry](https://www.extremetech.com/computing/243079-upcoming-windows-update-reduces-spying-microsoft-still-mum-data-collects). Along with that, Microsoft collects a [lot more data from Windows 10](https://web.archive.org/web/20210711143017/https://privacytools.io/operating-systems/#win10). | ||||
|  | ||||
| With the launch of Windows 11, a lot of [other](https://www.windowscentral.com/one-thing-microsoft-didnt-discuss-windows-11-privacy) [concerns](https://www.pcworld.com/article/539183/windows-11-review-an-unnecessary-replacement-for-windows-10.html) were raised, such as: | ||||
|  | ||||
| - Integration of Microsoft Teams into the OS, which would encourage users to switch to the service, allowing Microsoft to collect even more data. | ||||
| - Removing the ability to have local accounts in Windows 11 Home, therefore forcing you to log into a Microsoft account so as to collect more data. | ||||
| - Having all data collection options on by default | ||||
| - Working with Amazon to bring Android apps to Windows through the Windows Subsystem for Android, likely allowing both Microsoft and Amazon to collect data about Android app usage on Windows. | ||||
| - Using users in a P2P way to distribute Windows updates to reduce load in Microsoft's servers without users' consent. | ||||
|  | ||||
| ## Choosing your Windows edition | ||||
|  | ||||
| While using Windows, it is better to select either Windows **Enterprise** Edition or **Education** Edition because it gives more control over the system for hardening it for privacy and security by giving access to stops the OS from sending any Telemetry data using GP Editor. | ||||
|  | ||||
| If you cannot get the above editions, you should opt for **Professional** Edition. | ||||
|  | ||||
| #### Editions to avoid  | ||||
|  | ||||
| - It is not recommended to use forks or modified versions of Windows such as Windows AME. It should be avoided at all cost. Since modified versions of Windows, such as AME, don't get updates, antivirus programs like Defender can fall out of date or be disabled entirely, opening you up to attacks. | ||||
|  | ||||
| - Windows **Home** edition is **not** recommended as it does not have many advantages that Professional edition provides such as BitLocker Drive Encryption, Hyper-V, Windows Sandbox, etc. It also uploads Bitlocker Encryption keys to Microsoft servers which actually defies the aspect of the encryption implemented as the key was supposed to be hold by the user. | ||||
|  | ||||
| ##### Recommendations | ||||
|  | ||||
| We recommend you choose Windows 11 over Windows 10 as it is the latest version and brings many security-related improvements with it by default such as [Secure Boot](https://docs.microsoft.com/en-us/windows-hardware/design/device-experiences/oem-secure-boot), [VBS](https://docs.microsoft.com/en-us/windows-hardware/design/device-experiences/oem-vbs), [HVCI](https://docs.microsoft.com/en-us/windows-hardware/drivers/bringup/device-guard-and-credential-guard), etc. Windows 10 will stop getting updates after [October 14, 2025](https://docs.microsoft.com/en-us/lifecycle/products/windows-10-home-and-pro). | ||||
|  | ||||
| ### Installing Windows | ||||
|  | ||||
| We recommend that you use the official [Media Creation tool](https://www.microsoft.com/software-download/windows11) to flash the ISO to the USB, over third-party options such as Rufus, Balena Etcher, etc., so that you don't tamper the ISO. | ||||
|  | ||||
| #### Downloading ISO | ||||
|  | ||||
| To download the ISO. Follow these steps : | ||||
|  | ||||
| - Download Media Creation tool under `Windows 11 Installation Media` | ||||
| - Open a Command prompt terminal in the directory where `mediacreationtool.exe` is downloaded. | ||||
| - And Input the following Command : | ||||
|     ``` | ||||
|     mediacreationtool.exe /Eula Accept /Retail /MediaArch x64 /MediaLangCode en-US /MediaEdition Enterprise | ||||
|     ``` | ||||
| - If it asks for Activation key, Use this Generic Key `XGVPP-NMH47-7TTHJ-W3FW7-8HV2C`. This will just allow you to download the ISO but activation is totally upon the user. | ||||
| - Accept the UAC prompt | ||||
| - Download the ISO file or flash to a USB as you wish | ||||
|  | ||||
| !!! info "Note" | ||||
|     - The ISO will consists **only** of Professional, Education & Enterprise edition with a size of ~4.2 GB (Instead of >5.5GB when you download the Multi-Edition ISO) when you download using the above way no other editions such as Home included in it. | ||||
|     - If you want to change the Language of the ISO file, Just change the `en-US` part with the appropriate language and country code as per your needs. | ||||
|  | ||||
| ### Activating Windows | ||||
|  | ||||
| Activating Education/Enterprise edition is different because for Enterprise Edition it needs to be a part of an enterprise network or buying an enterprise License for several devices and use it for your one device & for Education Edition it needs to be a part of school network or managed by a school administrator. | ||||
|  | ||||
| For activating Professional edition, you can buy the license key from resellers (not recommended) or the [Microsoft Store](https://www.microsoft.com/d/windows-11-pro/dg7gmgf0d8h4?rtc=1). | ||||
|  | ||||
| If you are currently using Pro and want to upgrade to Enterprise. Then, Follow the guide [here](https://www.kapilarya.com/how-to-upgrade-windows-11-pro-to-enterprise-edition) | ||||
|  | ||||
| !!! abstract "Note" | ||||
|     This guide will be mostly on Windows 11 but some of the recommendations can be applied to Windows 10 too. | ||||
|  | ||||
| !!! danger "Warning" | ||||
|     If you are going to install Windows 11, Then install it only on supported devices and it is not recommended to use tools/scripts that are available online to bypass the requirements which totally breaks the security of Windows 11 which it is aimed for. | ||||
|  | ||||
|     Never download **Pirated ISO Files** | ||||
|  | ||||
| *[GP]: Group Policy | ||||
| *[VBS]: Virtualization-Based Security | ||||
| *[HVCI]: Hypervisor-Protected Code Integrity | ||||
| *[AME]: Ameliorated | ||||
| *[P2P]: Peer-to-Peer | ||||
							
								
								
									
										80
									
								
								docs/os/windows/privacy.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,80 @@ | ||||
| --- | ||||
| title: Privacy in Windows | ||||
| icon: material/incognito | ||||
| --- | ||||
|  | ||||
| ## Using Microsoft account | ||||
|  | ||||
| You should never sign-in to Windows with a Microsoft account. Signing-in to applications like Microsoft Office (which some users are required to do for their school or company) will trigger a dark pattern offering you to sign in to Windows, which will connect your device to your Microsoft account, and make it easier to send data to Microsoft servers and it is critical to reject this offer. | ||||
|  | ||||
| It’s worth noting that according to [this study](https://www.autoriteitpersoonsgegevens.nl/sites/default/files/atoms/files/public_version_dutch_dpa_informal_translation_summary_of_investigation_report.pdf) it seems that Windows collects more telemetry when signed into a Microsoft Account. | ||||
|  | ||||
|  | ||||
|  | ||||
| You should log in to that specific app only if you need to. | ||||
|  | ||||
| or  | ||||
|  | ||||
| Create another standard user account and connect it to Microsoft account if you are required for School or Work and keep the apps to that account alone. By restricting other data drive access, it is fully isolated from other profiles. | ||||
|  | ||||
| ## Telemetry | ||||
|  | ||||
| To disable telemetry at full level, Open Group policy and navigate to `Computer Configuration` > `Administrative Templates` > `Windows Components` > `Data Collection and Preview builds` and choose as required | ||||
|  | ||||
|  | ||||
|  | ||||
| The above works only if you use Enterprise or Education edition. If Professional, It will send required (Basic) data. | ||||
|  | ||||
| If you read this article - [https://www.softscheck.com/en/blog/windows-10-enterprise-telemetry-analysis/](https://www.softscheck.com/en/blog/windows-10-enterprise-telemetry-analysis/), Enterprise even sends data even though telemetry is disabled. But there is no updated info about this available. | ||||
|  | ||||
| Disabling full telemtry or sending basic data to Microsoft is totally upto the user's threat model. | ||||
|  | ||||
| - [ ] Disable `Automatic Sample Submission` in Windows Defender will send your files as a sample for Signature Database and might leak your data. You can do it via the below Group Policy so to not prompt you again and again constantly. | ||||
|     ``` | ||||
|     Computer Configuration > Administrative Templates > Windows Components > Microsoft Defender Antivirus > MAPS > Send file samples when further analysis is required to Never Send. | ||||
|     ``` | ||||
|  | ||||
| - [ ] Disable Windows spotlight by navigating to `User Configuration` > `Administrative Templates` > `Windows Components` > `Cloud Content` and setting **Turn off all Windows Spotlight features** policy to disabled. | ||||
|         !!! note | ||||
|         This explicitly disables Windows spotlight features in Lockscreen and Desktop to severe unnecessary between Microsoft servers and the device. | ||||
|  | ||||
| - [ ] Disable in Bing integration in Windows search, by navigating to `Computer Configuration\Administrative Templates\Windows Components\Search\Don't search the web or display web results`. This way your search queries for local indexed data is not sent to Microsoft. | ||||
|  | ||||
| - [ ] Disable notification in the Lock screen in Windows settings | ||||
|      | ||||
|  | ||||
| - [ ] Disable Online Speech recognition and Voice activation | ||||
|          | ||||
|          | ||||
|  | ||||
| - [ ] Disable delivery optimization in Windows Update settings. | ||||
|  | ||||
| - Check all the App permissions and allow only necessary ones. | ||||
|  | ||||
| ## Hide MAC Address | ||||
|  | ||||
| Go to `Settings` > `Network & Internet` > `Wifi` | ||||
|  | ||||
| Enable **Random hardware addresses** | ||||
|  | ||||
| ## Restrict access to data drives | ||||
|  | ||||
| To prevent other users from accessing your secondary data drives. Type `gpedit.msc` in Windows Run dialog box. | ||||
|  | ||||
| Go to `User Configuration` > `Administrative Templates` > `Windows Components` > `File Explorer` and set the Group Policy as below. | ||||
|  | ||||
|  | ||||
|  | ||||
| The above configuration will restrict other users to the OS drive where Windows is installed. Making total isolation between your Account and other user account. | ||||
|  | ||||
| If it's a shared drive with another person but you don't want the user to access sensitive data then use EFS. EFS encrypts the documents so that the user who encrypted it can only access it and not others. | ||||
|  | ||||
|  | ||||
|  | ||||
| It is better to export the Private key certificate and store in a safe place so as to use the file later in other devices. To do so, | ||||
|  | ||||
| Press, ++win+r++, Then type `certmgr.msc`, Under `Personal` > `Certificates`. Click the certificate that contains your username. Right Click and choose export. If you find this too tricky, then after using EFS for first time. You will see an encrypted locker Icon in system tray which help you in exporting on clicking it. | ||||
|  | ||||
| To import in another device, simply open and install this certificate in that device and choose the above location. Then you can access EFS encrypted files in other system too. | ||||
|  | ||||
| *[EFS]: Encrypted File System | ||||
							
								
								
									
										147
									
								
								docs/os/windows/sandboxing.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,147 @@ | ||||
| --- | ||||
| title: Application Sandboxing | ||||
| icon: octicons/apps-16 | ||||
| --- | ||||
|  | ||||
| ## Native Application Sandboxing | ||||
|  | ||||
| ### Application Packaging by Windows | ||||
|  | ||||
| Windows has two types of application packaging such as `.exe`/`.msi` (Win32) and `.appx`/`.msix` (UWA). | ||||
|  | ||||
| #### Universal Windows Application (UWA) | ||||
|  | ||||
| UWAs are processes that operate within the `AppContainer` is an application sandbox environment, which implements mechanisms for the restriction of `AppContainer` processes in terms of what system resources they can access. Basically, Application that is fully isolated and only given access to certain resources. | ||||
|  | ||||
| #### Win32 Apps | ||||
|  | ||||
| Win32 is the application platform of choice for developing and running classic Windows applications, that  | ||||
| is, Win32 applications, that require direct access to Windows and hardware.  | ||||
|  | ||||
| The core of Win32 is the Win32 API implemented in the Windows SubDLLs (DLLs) and the ntdll.dll library file. With the combination of `SubDLLs` and `ntdll.dll`, the Win32 application has direct access to full system resources. | ||||
|  | ||||
| #### A comparison between UWA and Win32 | ||||
|  | ||||
| | UWAs    | Windows | | ||||
| | :--------- | :---------------------------------- | | ||||
| |UWAs run as restricted, containerized `AppContainer` processes that run by accessing the WinRT API, a subset of COM functionalities and the Win32 API. They have specific properties that define process restrictions in terms of the system resources that processes can access.| Win32 applications run as Windows native, traditional processes that run by accessing the Win32 API and COM functionalities to their full extent and a subset of the WinRT API to directly access all system resources. They do not run as restricted processes, all system functionalities are by design directly available to them.| | ||||
| |Only a single instance of a given UWA may run at a given time. | Any number of instances of a given Win32 application may run simultaneously. | ||||
| |UWAs are distributed as application packages, archive files with a pre-defined format and required content that is necessary for the deployment and operation of UWAs |The way in which Win32 applications are distributed is not restricted by the operating system. It is defined by the application vendors. | ||||
|  | ||||
| The above comparison gives a clear cut that UWA/UWP apps are the best ones to use in terms of sandboxing the app. | ||||
|  | ||||
|  | ||||
| ### Choosing the way to install software | ||||
|  | ||||
| UWA apps are primarily distributed through Microsoft store and are counter-signed by Microsoft while as third party UWA's are signed by the vendor without Microsoft's signature. | ||||
|  | ||||
| It is recommended to use the UWA apps as they are sandboxed into their own containers. | ||||
|  | ||||
| And for Win32 apps. If you are required to use Win32 apps. Install the application in the host and run it using [Windows Sandbox](/windows/sandboxing/#run-programs-instantly-in-sandbox). | ||||
|  | ||||
| It is **recommended** to install in host and use in Sandbox to reduce your time installing the software again and again in Windows Sandbox. | ||||
|  | ||||
| ### Finding Win32 and UWP apps in Windows Store | ||||
|  | ||||
| Generally, apps available in Microsoft store was UWP only before Windows 11 was launched but after the launch both Win32 and UWP apps co-exist in the store. | ||||
|  | ||||
| At this point, it is difficult to differentiate between Win32 and UWP apps. To find which is UWP or Win32. Read below: | ||||
|  | ||||
| When you see an app in store and scroll down to *Additional Information*  section and see if it asks for certain permissions like in the image below: | ||||
|  | ||||
|  | ||||
|  | ||||
| If the Win32 App, Microsoft store will explicitly state that it is`Provided and Updated by `****` ` and `Uses all System resources` as in the image below: | ||||
|  | ||||
|  | ||||
|  | ||||
| !!! note "Un-sandboxed UWP apps" | ||||
|     Some UWP apps in the store due to the lift of restrictions in Microsoft store developers can submit the app with a property named `runFullTrust` which disables sandboxing of that UWP application and shows that `Uses all System Resources` in *Additional Information* section such as Firefox. By this you can know if a UWP app is sandboxed or not. | ||||
|  | ||||
|     If it is sandboxed, it will show only certain permissions in *Additional Information* section. | ||||
|  | ||||
| !!! abstract "Note" | ||||
|     Most apps will ask that if the app needs to be used for all users or just for your user account. It is best you keep the app to your user Account. So, We achieve better sandboxing between different user accounts. | ||||
|  | ||||
| ##### Another way to find | ||||
|  | ||||
| [rg-adguard.net](https://store.rg-adguard.net/) is a third party Microsoft store app which can be used to download `.appx` files (Installer for UWP) and install UWP apps. You can use this site to download Age Restricted apps in store and Install it. **Note** that paid apps don't work unless you connect a Microsoft Account. | ||||
|  | ||||
|  | ||||
| ## Using Winget to Install Sofware | ||||
|  | ||||
| Windows Package Manager winget command-line tool is bundled with Windows 11 and modern versions of Windows 10 by default as the App Installer. | ||||
|  | ||||
| The winget command line tool enables users to discover, install, upgrade, remove and configure applications on Windows 10 and Windows 11 computers. This tool is the client interface to the Windows Package Manager service. | ||||
|  | ||||
| More information here : [https://learn.microsoft.com/en-us/windows/package-manager/winget/](https://learn.microsoft.com/en-us/windows/package-manager/winget/) | ||||
|  | ||||
| The Winget tool is a powerful tool to install apps that are safe, trusted and official ones. This should be used to avoid sketchy installers. | ||||
|  | ||||
| Even you have apps installed via the traditional installer setup. You can continue using winget | ||||
|  | ||||
| A Quick demo by ThioJoe - [https://youtu.be/uxr7m8wDeGA](https://youtu.be/uxr7m8wDeGA) | ||||
|  | ||||
| Detailed info about the tool by Microsoft - [https://youtu.be/Lk1gbe_JTpY](https://youtu.be/Lk1gbe_JTpY) | ||||
|  | ||||
| If you understood about Winget, then this tool - [https://winstall.app/](https://winstall.app/) is suggested to bulk install apps. | ||||
|  | ||||
| Note : Be sure to install via Winget or using MSI installer to upgrade the app easily. | ||||
|  | ||||
| #### Benefits of winget | ||||
|  | ||||
| There are general advantages in having a package manager regardless of the operating system. | ||||
|  | ||||
| - Security : The packages that the package manager includes are usually safe because they’re verified by maintainers. | ||||
| - Automation : It’s easier to install or uninstall N applications using a package manager. No need to do it manually. | ||||
| - Maintenance : With a package manager usually you can update all your applications, including configurations. | ||||
| Exploration. Instead of searching manually in a browser for an application you can use the package manager. Since it’s centralized it should be easier to find what you want. | ||||
|  | ||||
| ## Windows Sandbox | ||||
|  | ||||
| Windows Sandbox provides a lightweight desktop environment to safely run applications in isolation. Software installed inside the Windows Sandbox environment remains "sandboxed" and runs separately from the host machine. | ||||
|  | ||||
| The sandbox is temporary like TailsOS running on a USB drive. When it's closed, all the software and files and the state are deleted. You get a brand-new instance of the sandbox every time you open it. | ||||
|  | ||||
| You can know more from the Official [Documentation](https://docs.microsoft.com/en-us/windows/security/threat-protection/windows-sandbox/windows-sandbox-overview). | ||||
|  | ||||
|  | ||||
| **Use case of Sandbox:** The Windows Sandbox can be used to run unknown software or if you want to isolate your Workspace from the host with only Specific set of apps, etc. | ||||
|  | ||||
| ### Using Sandbox | ||||
|  | ||||
| To use Sandbox, you can create a configuration file as per the official Microsoft [Documentation](https://docs.microsoft.com/en-us/windows/security/threat-protection/windows-sandbox/windows-sandbox-configure-using-wsb-file) for your needs. | ||||
|  | ||||
| So, when opening the file, sandbox opens with the Configurations you had set up in your file. | ||||
|  | ||||
| If you do not understand the documentation, you can use [Windows Sandbox Editor](https://github.com/damienvanrobaeys/Windows_Sandbox_Editor) instead. It is a GUI application that can be used to create configuration files easily. | ||||
|  | ||||
| ??? note "Regarding Windows Sandbox Editor" | ||||
|     The repository doesn't provide a package. So, you need to download the whole codebase. After, extracting the zip Windows Defender or other Antivirus software may flag the [exe](https://github.com/damienvanrobaeys/Windows_Sandbox_Editor/tree/master/EXE) file as a malware. So, it is recommended to install it via the [Powershell Script](https://github.com/damienvanrobaeys/Windows_Sandbox_Editor/tree/master/Install%20on%20desktop%20(in%20case%20of%20issue%20with%20EXE)) they provide. | ||||
|  | ||||
|     By default, You cannot execute Scripts in Powershell and it is restricted to commands only. It is recommend you allow the Terminal to `Unrestricted` mode and use it to install the editor via Script after that change it back to `Restricted` [execution policy](https://docs.microsoft.com/en-us/powershell/module/microsoft.powershell.core/about/about_execution_policies?view=powershell-7.2) to prevent accidental execution of malicious scripts in the future. | ||||
|  | ||||
| ### Run programs instantly in Sandbox | ||||
|  | ||||
| [Run in Sandbox](https://github.com/damienvanrobaeys/Run-in-Sandbox) is a tool to quickly run files in Windows Sandbox with a right click. | ||||
|  | ||||
| We recommend you to use this software as it is convenient and easy to use and even credited by Microsoft.  | ||||
|  | ||||
| A full guide on How to use it can be found here: [https://www.systanddeploy.com/2021/11/run-in-sandbox-quick-way-to-runextract.html](https://www.systanddeploy.com/2021/11/run-in-sandbox-quick-way-to-runextract.html) | ||||
|  | ||||
| Note: The same note of installing sandbox editor via PowerShell also applies here except this doesn't provide an `exe` at all. | ||||
|  | ||||
| This page is based on the German BSI project - [SiSyPHuS Win10](https://www.bsi.bund.de/EN/Topics/Cyber-Security/Recommendations/SiSyPHuS_Win10/SiSyPHuS_node.html)'s Work Package 9 Dcoument. | ||||
|  | ||||
| **For Advanced Users :** | ||||
|  | ||||
| Sandboxie Plus, is a Sandboxing tool which uses File system and registry Virtualization techniques to sandbox every apps and at the same data not being lost like Windows Sandbox. | ||||
|  | ||||
| Use this at your own Risk ! | ||||
|  | ||||
| *[UWA]:Universal Windows Applications | ||||
| *[UWP]:Universal Windows Platform | ||||
| *[SubDLLs]: Subsystem Dynamic link libraries | ||||
| *[ntdll.dll]: A core Windows library file that implements functions for interaction with the kernel. | ||||
| *[WinRT]: Windows Runtime | ||||
| *[COM]: Component Object Model | ||||