2020-01-31 18:17:07 -08:00
# PowerToys MSIX installer instructions
2019-09-04 18:26:26 +02:00
2020-01-31 18:17:07 -08:00
## One-time tasks
2020-01-28 15:01:17 -08:00
2020-01-31 18:17:07 -08:00
### Create and install the self-sign certificate
2020-01-15 10:15:24 -08:00
For the first-time installation, you'll need to generate a self-signed certificate. The script below will generate and add a cert to your [TRCA store ](https://docs.microsoft.com/en-us/windows-hardware/drivers/install/trusted-root-certification-authorities-certificate-store ).
1. Open `Developer PowerShell for VS` as an Admin
2. Navigate to your repo's `installer\MSIX`
3. Run `.\generate_self_sign_cert.ps1`
2019-12-20 19:12:52 +03:00
2020-01-31 18:17:07 -08:00
**Note:** if you delete the folder, you will have to regenerate the key
### Elevate `Developer PowerShell for VS` permissions due to unsigned file
2020-01-28 15:01:17 -08:00
`msix_reinstall.ps1` is unsigned, you'll need to elevate your prompt.
1. Open `Developer PowerShell for VS` as admin
2. Run `Set-ExecutionPolicy -executionPolicy Unrestricted`
2020-02-07 14:22:49 -08:00
### Allow Sideloaded apps
In order to install the MSIX package without using the Microsoft Store, sideloading apps needs to be enabled. This can be done by enabling `Developer Options > Sideload apps` or `Developer Options > Developer mode` .
2020-01-31 18:17:07 -08:00
## To Build MSIX
2020-01-15 10:15:24 -08:00
1. Make sure you've built the `Release` configuration of `powertoys.sln`
2. Open `Developer PowerShell for VS`
3. Navigate to your repo's `installer\MSIX`
4. Run `.\msix_reinstall.ps1` from the devenv powershell
2019-12-20 19:12:52 +03:00
2020-01-31 18:17:07 -08:00
### What msix_reinstall.ps1 does
2019-12-20 19:12:52 +03:00
`msix_reinstall.ps1` removes the current PowerToys installation, restarts explorer.exe (to update PowerRename shell extension), builds `PowerToys-x64.msix` package, signs it with a PowerToys_TemporaryKey.pfx, and finally installs it.
2020-01-15 10:15:24 -08:00
2020-01-31 18:17:07 -08:00
### Removing all .msi/.msix PowerToys installations
2019-12-18 13:19:15 +03:00
```ps
$name='PowerToys'
Get-AppxPackage -Name $name | select -ExpandProperty "PackageFullName" | Remove-AppxPackage
gwmi win32_product -filter "Name = '$name'" -namespace root/cimv2 | foreach {
if ($_.uninstall().returnvalue -eq 0) { write-host "Successfully uninstalled $name " }
else { write-warning "Failed to uninstall $name." }
}
```
2020-01-28 15:01:17 -08:00
2020-01-31 18:17:07 -08:00
# MSI Build instructions (Deprecated)
1. Install the [WiX Toolset Visual Studio 2019 Extension ](https://marketplace.visualstudio.com/items?itemName=RobMensching.WiXToolset ).
2. Install the [WiX Toolset build tools ](https://wixtoolset.org/releases/ ) in the development machine.
3. Open `powertoys.sln` , select the "Release" and "x64" configurations and build the `PowerToysSetup` project.
4. The resulting installer will be built to `PowerToysSetup\bin\Release\PowerToysSetup.msi` .