feat(app update): finished the app build / deploy functions and a scripts migration
This commit is contained in:
@@ -1,14 +1,245 @@
|
||||
$serverDataFile = "..\services\server\utils\serverData.json"
|
||||
param (
|
||||
[string]$server,
|
||||
[string]$token,
|
||||
[string]$location,
|
||||
[string]$devFolder,
|
||||
[string]$serverIP,
|
||||
[string]$build,
|
||||
[string]$type,
|
||||
[string]$username,
|
||||
[string]$admpass,
|
||||
[string]$obslst,
|
||||
[string]$obsBuild
|
||||
)
|
||||
|
||||
# Convert the plain-text password to a SecureString
|
||||
$securePass = ConvertTo-SecureString $admpass -AsPlainText -Force
|
||||
$credentials = New-Object System.Management.Automation.PSCredential($username, $securePass)
|
||||
|
||||
$jsonContent = Get-Content -Path $serverDataFile -Raw
|
||||
# lets get the version of the app we are updating
|
||||
$pkgFile = "$devFolder\package.json"
|
||||
$package = Get-Content -Path $pkgFile -Raw | ConvertFrom-Json
|
||||
|
||||
# Convert the JSON content to a PowerShell object
|
||||
$jsonObject = $jsonContent | ConvertFrom-Json
|
||||
$version = "$($package.version)-$($package.admConfig.build -1)"
|
||||
|
||||
# Access the data in the JSON object
|
||||
$servers = $jsonObject.servers
|
||||
# Checking to make sure the server is up and online
|
||||
Write-Output "Checking if $($token) is online to update."
|
||||
$pingResult = Test-Connection -ComputerName $serverIP -Count 2 -Quiet
|
||||
|
||||
if (-not $pingResult) {
|
||||
Write-Output "Server $($server) $($serverIP) is NOT reachable. Exiting script."
|
||||
exit 1 # Terminate the script with a non-zero exit code
|
||||
}
|
||||
|
||||
Write-Output "Server $($server) ($serverIP) is online."
|
||||
|
||||
Write-Host $servers
|
||||
# get the file name we want to grab
|
||||
|
||||
$buildZip = "lstv2-$version.zip"
|
||||
|
||||
if (-Not (Test-Path -Path "$($build)\$($buildZip)")) {
|
||||
Write-Host "Build is missing from the build folder."
|
||||
Write-host $buildZip
|
||||
exit
|
||||
}
|
||||
|
||||
Write-Host "---------------Starting the update Process----------------------------------"
|
||||
Write-Host "File to be copied over is $buildZip"
|
||||
Write-Host "Coping files to $($server)"
|
||||
$destination = "\\$($server)\$($location)" -replace ":", "$"
|
||||
Write-Host $destination
|
||||
Write-Host "Forcing the removal of the mapped drive."
|
||||
Get-PSDrive -Name "z" -ErrorAction SilentlyContinue | Remove-PSDrive -Force
|
||||
|
||||
# Create a mapped drive with credentials using New-PSDrive for the current session
|
||||
|
||||
try {
|
||||
|
||||
New-PSDrive -Name "z" -PSProvider FileSystem -Root $destination -Credential $credentials
|
||||
|
||||
# Create the update folder if it doesn't exist
|
||||
if (-not (Test-Path -Path $destination)) {
|
||||
New-Item -ItemType Directory -Path $destination -Force
|
||||
}
|
||||
|
||||
# Copying files to the server
|
||||
Write-Host "Copying files to $($server)"
|
||||
Copy-Item -Path "$($build)\$($buildZip)" -Destination "z:\" -Recurse -Force
|
||||
Write-Host "Files copied to $($server)"
|
||||
} catch {
|
||||
Write-Host "Error: $_"
|
||||
} finally {
|
||||
# Remove the mapped drive after copying
|
||||
if (Get-PSDrive -Name "z" -ErrorAction SilentlyContinue) {
|
||||
Write-Host "Removing mapped drive..."
|
||||
Remove-PSDrive -Name "z"
|
||||
}
|
||||
}
|
||||
|
||||
write-Host $extractedFolderPath = "$server\$location$(if ($token -eq "usiow2") { "_2" })"
|
||||
|
||||
# The script that runs inside the plant.
|
||||
$plantFunness = {
|
||||
param ($server, $token, $location, $buildFile, $buildLoc, $obslst, $obsBuild)
|
||||
|
||||
$localPath = $location -replace '\$', ':'
|
||||
$serverFile = "$($localPath)\$buildFile"
|
||||
$serverPath = "$($localPath)"
|
||||
|
||||
Write-Host "In the plant we go!!!!!"
|
||||
Write-Host "Unzipping the folder..."
|
||||
|
||||
$extractedFolderPath = $serverPath
|
||||
|
||||
# Extract the files to the build path
|
||||
try {
|
||||
# Expand the archive
|
||||
Expand-Archive -Path $serverFile -DestinationPath $extractedFolderPath -Force
|
||||
|
||||
# Delete the zip file after extraction
|
||||
Write-Host "Deleting the zip file..."
|
||||
Remove-Item -Path $serverFile -Force
|
||||
} catch {
|
||||
Write-Host "Error: $_"
|
||||
exit 1 # Exit with a non-zero code if there's an error
|
||||
}
|
||||
|
||||
Write-Host "-----------------------Dealing with LSTv1 Stuff ------------------------------------"
|
||||
try {
|
||||
# Expand the archive
|
||||
Expand-Archive -Path "$($localPath)\$($obsBuild)" -DestinationPath $obslst -Force
|
||||
|
||||
# Delete the zip file after extraction
|
||||
Write-Host "Deleting the zip file..."
|
||||
Remove-Item -Path "$($localPath)\$($obsBuild)" -Force
|
||||
} catch {
|
||||
Write-Host "Error: $_"
|
||||
exit 1 # Exit with a non-zero code if there's an error
|
||||
}
|
||||
|
||||
############################################################################
|
||||
Write-Host "Stopping the services to do the updates, pkgs and db changes."
|
||||
|
||||
Write-Host "Stopping services to update"
|
||||
$serviceGateway = "LST-Gateway$(if ($token -eq "usiow2") { "_2" })"
|
||||
$serviceAuth = "LST-Auth$(if ($token -eq "usiow2") { "_2" })"
|
||||
$serviceSystem = "LST-System$(if ($token -eq "usiow2") { "_2" })"
|
||||
$serviceApp = "LST-App$(if ($token -eq "usiow2") { "_2" })"
|
||||
$serviceFrontEnd = "LST-frontend$(if ($token -eq "usiow2") { "_2" })"
|
||||
$serviceOcme = "LST-Ocme$(if ($token -eq "usiow2") { "_2" })"
|
||||
$serviceLstV2 = "LSTV2$(if ($token -eq "usiow2") { "_2" })"
|
||||
|
||||
if($token -eq "usday1"){
|
||||
Write-Host "Stopping $($serviceOcme)"
|
||||
Stop-Service -DisplayName $serviceOcme -Force
|
||||
}
|
||||
|
||||
Write-Host "Stopping $($serviceGateway)"
|
||||
Stop-Service -DisplayName $serviceGateway -Force
|
||||
Start-Sleep -Seconds 1
|
||||
|
||||
Write-Host "Stopping $($serviceAuth)"
|
||||
Stop-Service -DisplayName $serviceAuth -Force
|
||||
Start-Sleep -Seconds 1
|
||||
|
||||
Write-Host "Stopping $($serviceSystem)"
|
||||
Stop-Service -DisplayName $serviceSystem -Force
|
||||
Start-Sleep -Seconds 1
|
||||
|
||||
Write-Host "Stopping $($serviceApp)"
|
||||
Stop-Service -DisplayName $serviceApp -Force
|
||||
Start-Sleep -Seconds 1
|
||||
|
||||
Write-Host "Stopping $($serviceFrontEnd)"
|
||||
Stop-Service -DisplayName $serviceFrontEnd -Force
|
||||
Start-Sleep -Seconds 1
|
||||
|
||||
Write-Host "Stopping $($serviceLstV2)"
|
||||
Stop-Service -DisplayName $serviceLstV2 -Force
|
||||
Start-Sleep -Seconds 1
|
||||
|
||||
#################################################################
|
||||
# Service removoal and making sure we have the new version added
|
||||
#################################################################
|
||||
|
||||
$appPath = $extractedFolderPath
|
||||
$nssmPath = $serverPath + "\nssm.exe"
|
||||
$npmPath = "C:\Program Files\nodejs\npm.cmd" # Path to npm.cmd
|
||||
|
||||
#################################################################
|
||||
# Removing all the old services
|
||||
#################################################################
|
||||
Write-Host "Removing services that are no longer used."
|
||||
& $nssmPath remove "LogisticsSupportTool" confirm
|
||||
& $nssmPath remove $serviceAuth confirm
|
||||
Start-Sleep -Seconds 5
|
||||
|
||||
## adding in lstAdm
|
||||
Write-Host "Adding $($serviceLstV2)... incase its missing."
|
||||
$commandToRun = "run start"
|
||||
$description = "logistics Support Tool"
|
||||
& $nssmPath install $serviceLstV2 $npmPath $commandToRun
|
||||
Write-Host "Setting the app directory"
|
||||
& $nssmPath set $serviceLstV2 AppDirectory $appPath
|
||||
Write-Host "Setting the description"
|
||||
& $nssmPath set $serviceLstV2 Description $description
|
||||
Write-Host "Setting recovery options"
|
||||
# Set recovery options
|
||||
sc.exe failure $serviceLstV2 reset= 0 actions= restart/5000/restart/5000/restart/5000
|
||||
|
||||
# Doing an install
|
||||
Write-Host "Running the install to make sure everything is updated."
|
||||
Set-Location $serverPath
|
||||
npm run prodinstall # --omit=dev
|
||||
Write-Host "Finished doing updates"
|
||||
Start-Sleep -Seconds 1
|
||||
|
||||
###########################################################
|
||||
# Old system still active until we have everything off it
|
||||
###########################################################
|
||||
Write-Host "Running install on obs server."
|
||||
Set-Location $obslst
|
||||
npm run newinstall # --omit=dev
|
||||
Write-Host "Update the frontend"
|
||||
npm run install:front
|
||||
npm run install:ui
|
||||
|
||||
Write-Host "Running db updates"
|
||||
npm run db:migrate
|
||||
Start-Sleep -Seconds 1
|
||||
npm run db:gen
|
||||
Start-Sleep -Seconds 1
|
||||
Write-Host "incase a new default setting was added we want to add it in."
|
||||
npm run db:init
|
||||
|
||||
###########################################################
|
||||
# Starting the services back up.
|
||||
###########################################################
|
||||
Write-Host "Starting the services"
|
||||
Write-Host "Starting $($serviceSystem)"
|
||||
Start-Service -DisplayName $serviceSystem
|
||||
Start-Sleep -Seconds 1
|
||||
Write-Host "Starting $($serviceGateway)"
|
||||
Start-Service -DisplayName $serviceGateway
|
||||
Start-Sleep -Seconds 1
|
||||
#Write-Host "Starting $($serviceAuth)"
|
||||
#Start-Service -DisplayName $serviceAuth
|
||||
#Start-Sleep -Seconds 1
|
||||
Write-Host "Starting $($serviceApp)"
|
||||
Start-Service -DisplayName $serviceApp
|
||||
Start-Sleep -Seconds 1
|
||||
Write-Host "Starting $($serviceFrontEnd)"
|
||||
Start-Service -DisplayName $serviceFrontEnd
|
||||
Start-Sleep -Seconds 1
|
||||
Write-Host "Starting $( $serviceLstV2)"
|
||||
Start-Service -DisplayName $serviceLstV2
|
||||
Start-Sleep -Seconds 1
|
||||
Write-Host "$($server) finished updating"
|
||||
|
||||
if($token -eq "usday1"){
|
||||
Write-Host "Starting $($serviceOcme)"
|
||||
Start-Service -DisplayName $serviceOcme
|
||||
}
|
||||
|
||||
}
|
||||
Invoke-Command -ComputerName $server -ScriptBlock $plantFunness -ArgumentList $server, $token, $location, $buildZip, $buildLoc, $obslst, $obsBuild -Credential $credentials
|
||||
Reference in New Issue
Block a user