PowerShell/scripts/install-ssh-server.ps1

46 lines
1.3 KiB
PowerShell
Raw Normal View History

2024-10-01 15:11:03 +02:00
<#
2021-07-13 21:10:02 +02:00
.SYNOPSIS
2022-07-12 19:54:16 +02:00
Installs a SSH server (needs admin rights)
2021-10-04 21:29:23 +02:00
.DESCRIPTION
2022-07-12 19:54:16 +02:00
This PowerShell script installs a SSH server (needs admin rights).
2021-07-13 21:10:02 +02:00
.EXAMPLE
2023-08-06 21:35:36 +02:00
PS> ./install-ssh-server.ps1
2021-07-13 21:10:02 +02:00
.LINK
https://github.com/fleschutz/PowerShell
2022-01-29 12:47:46 +01:00
.NOTES
2022-07-12 19:54:16 +02:00
Author: Markus Fleschutz | License: CC0
2021-03-25 17:24:31 +01:00
#>
2021-09-11 11:37:22 +02:00
#Requires -RunAsAdministrator
2021-03-25 17:24:31 +01:00
try {
$StopWatch = [system.diagnostics.stopwatch]::startNew()
if ($IsLinux) {
& sudo apt install openssh-server
} else {
2021-09-14 19:47:42 +02:00
# Install the OpenSSH Server
Add-WindowsCapability -Online -Name OpenSSH.Server~~~~0.0.1.0
# Start the sshd service
Start-Service sshd
2021-09-14 19:47:42 +02:00
# OPTIONAL but recommended:
Set-Service -Name sshd -StartupType 'Automatic'
2021-09-14 19:47:42 +02:00
# Confirm the firewall rule is configured. It should be created automatically by setup.
Get-NetFirewallRule -Name *ssh*
# There should be a firewall rule named "OpenSSH-Server-In-TCP", which should be enabled
# If the firewall does not exist, create one
New-NetFirewallRule -Name sshd -DisplayName 'OpenSSH Server (sshd)' -Enabled True -Direction Inbound -Protocol TCP -Action Allow -LocalPort 22
}
2021-03-25 17:24:31 +01:00
[int]$Elapsed = $StopWatch.Elapsed.TotalSeconds
2024-10-01 13:37:53 +02:00
"✅ installed and started SSH server in $Elapsed sec"
2021-09-27 10:09:45 +02:00
exit 0 # success
2021-03-25 17:24:31 +01:00
} catch {
2022-04-13 12:06:32 +02:00
"⚠️ Error in line $($_.InvocationInfo.ScriptLineNumber): $($Error[0])"
2021-03-25 17:24:31 +01:00
exit 1
}