# This script migrates Cryptomator settings for all local users on Windows in case the users uses custom directories as mountpoint # See also https://github.com/cryptomator/cryptomator/pull/2654. # # TODO: This script should be evaluated in a yearly interval if it is still needed and if not, should be removed # #Requires -RunAsAdministrator #Get all active, local user profiles $profileList = 'HKLM:\SOFTWARE\Microsoft\Windows NT\CurrentVersion\ProfileList' $localUsers = Get-LocalUser | Where-Object {$_.Enabled} | ForEach-Object { $_.Name} Get-ChildItem $profileList | ForEach-Object { $_.GetValue("ProfileImagePath") } | Where-Object { $profileNameMatches = ($_ | Select-String -Pattern "\\([^\\]+)$").Matches if($profileNameMatches.Count -eq 1) { #check if the last path part is contained in the local user name list #otherwise do not touch it return $localUsers.Contains($profileNameMatches[0].Groups[1].Value) } else { return $false; } } | ForEach-Object { $settingsPath = "$_\AppData\Roaming\Cryptomator\settings.json" if(!(Test-Path -Path $settingsPath -PathType Leaf)) { #No settings file, nothing to do. return; } $settings = Get-Content -Path $settingsPath | ConvertFrom-Json if($settings.preferredVolumeImpl -ne "FUSE") { #Fuse not used, nothing to do return; } #check if customMountPoints are used $atLeastOneCustomPath = $false; foreach ($vault in $settings.directories){ $atLeastOneCustomPath = $atLeastOneCustomPath -or ($vault.useCustomMountPath -eq "True") } #if so, use WinFsp Local Drive if( $atLeastOneCustomPath ) { Add-Member -Force -InputObject $settings -Name "mountService" -Value "org.cryptomator.frontend.fuse.mount.WinFspMountProvider" -MemberType NoteProperty $newSettings = $settings | Select-Object * -ExcludeProperty "preferredVolumeImpl" ConvertTo-Json $newSettings | Set-Content -Path $settingsPath } }