Remote Powershell scripting using VS Code on a Mac

Make your MacOS device a windows powershell powerhouse.

Being a Microsoft centric engineer with a Mac OS laptop has raised plenty of eyebrows during meetings. I’m sure there have been times people have internally questioned my credentials. Who can blame them? Walking into a meeting to talk about specific windows issues, only to open up my mac, seems completely hypocritical.

We all have our reasons for what devices, applications, operating systems we choose. My reasons typically boil down to the fact that I’m in the Apple ecosystem. I tried throwing myself in to the land of Microsoft, but they failed to impress. Don’t believe me, I was one of the 3 people who owned a Windows Phone. Only recently has Windows 10 piqued my interest, but the integration between devices is still plain awful, IMO.

This leads me to what’s always been the crux of my BYOD mac whilst working on Windows issues. Creating powershell scripts typically meant that I would bootcamp into windows, connect to a VM console or RDP to another device. This was plain awful. Typing delay, loss of native multitasking, confusion as to where source code resides and, as menial as this seems, awful text rendering meant that something needed to be done.

</rant>

The solution

It turns out you can have your cake and eat it. Who knew?

Turns out the team working on VS Code knew.

VS Code is an amazing application that should be in almost all IT professionals toolkit. It’s insanely powerful, whilst remaining quite simple. Seriously, if you haven’t checked it out, that will be the biggest take away from this post.

Go. Now. We’ll wait.

High level

The setup consists of the following:

  • My MacBook Pro, you guessed it, running MacOS
  • Visual Studio Code
  • A Windows Server 2016 VM
  • OpenSSH 7.7 - Later versions currentl have a bug that will prevent this solution from working

This setup gives me the flexibility I’ve always wanted.

  • Native text rendering on my mac, with no keyboard passthrough or lag.
  • Source Code stored on my mac
  • Native powershell debugging running on my target environment

The Setup

1. Setup Open SSH

I’m a nice guy, so you can read the text after this, or just copy paste the below code block.

1
2
3
4
5
6
Invoke-WebRequest -Uri "https://github.com/PowerShell/Win32-OpenSSH/releases/download/v7.7.2.0p1-Beta/OpenSSH-Win64.zip" -OutFile OpenSSH-Win64.zip
Unblock-File OpenSSH-Win64.zip
Expand-Archive OpenSSH-Win64.zip -destination 'C:\Program Files'
& 'C:\Program Files\OpenSSH-Win64\install-sshd.ps1'
Get-Service ssh* | Start-Service
Get-Service ssh* | Set-Service -StartupType Automatic

Whats the above doing? Its really simple.

  1. Download the ZIP file from github
  2. Unblock the zip file, so that the executables can be run
  3. Extract the archive into the C:\Program Files directory
  4. Run the provided install powershell script
  5. Start the SSH services
  6. Set the SSH services to automatic

Running this will install 2 services that will let you SSH into the machine.

2. Install VS Code + Extensions

VS Code is really straight forward to install. Download for your OS flavour and run the install, following their documentation.

Once installed, open the marketplace and install Remote-SSH.

RemoteSSH

3. Connect to the remote machine

When you have your workspace open, open the command pallet (F1 or ⌘+⇧+P) and type Remote-SSH: Connect to Host

RemoteSSHConnecting

Follow the prompts, entering your hostname, username and password. Its worth noting that you may have to accept the remote host key. It maybe simpler to do this through a standard SSH session if you have any issues.

When authenticating, the username and password are the standard windows username and passwords on the remote host. You can use domain credentials also using the format username@domain@host !

This process will take a few moments to setup the VS Code server on your remote host. You host will need internet connectivity for this. Its an open bug to add functionality for offline systems, but that’s currently unsupported.

4. Enjoy the benefits.

You can now reap the rewards of setting up remote-ssh. Here you can see that I have a simple one liner to query the OS, written and displayed on my Mac, running on the Windows Server instance. Pure joy 😊.

RemotelyDebugging