diff --git a/dev/migrate.ps1 b/dev/migrate.ps1 index 52a622eba7..7485b75e76 100755 --- a/dev/migrate.ps1 +++ b/dev/migrate.ps1 @@ -6,12 +6,44 @@ # in the future and investigate if we can migrate back. # docker-compose --profile mssql exec mssql bash /mnt/helpers/run_migrations.sh @args -docker run ` - -v "$(pwd)/helpers/mssql:/mnt/helpers" ` - -v "$(pwd)/../util/Migrator:/mnt/migrator/" ` - -v "$(pwd)/.data/mssql:/mnt/data" ` - --env-file .env ` - --network=bitwardenserver_default ` - --rm ` - mcr.microsoft.com/mssql-tools ` - /mnt/helpers/run_migrations.sh @args +param([switch]$all = $false, [switch]$postgres = $false, [switch]$mysql = $false, [switch]$mssql = $false) + +if (!$all -and !$postgres -and !$mysql) { + $mssql = $true; +} + +if ($all -or $postgres -or $mysql) { + dotnet ef *> $null + if ($LASTEXITCODE -ne 0) { + Write-Host "Entity Framework Core tools were not found in the dotnet global tools. Attempting to install" + dotnet tool install dotnet-ef -g + } +} + +if ($all -or $mssql) { + Write-Host "Starting Microsoft SQL Server Migrations" + docker run ` + -v "$(pwd)/helpers/mssql:/mnt/helpers" ` + -v "$(pwd)/../util/Migrator:/mnt/migrator/" ` + -v "$(pwd)/.data/mssql:/mnt/data" ` + --env-file .env ` + --network=bitwardenserver_default ` + --rm ` + mcr.microsoft.com/mssql-tools ` + /mnt/helpers/run_migrations.sh @args +} + +$currentDir = Get-Location + +if ($all -or $mysql) { + Write-Host "Starting MySQL Migrations" + Set-Location "$currentDir/../util/MySqlMigrations/" + dotnet ef database update +} +if ($all -or $postgres) { + Write-Host "Starting PostgreSQL Migrations" + Set-Location "$currentDir/../util/PostgresMigrations/" + dotnet ef database update +} + +Set-Location "$currentDir"