Skip to content

Latest commit

 

History

History
50 lines (39 loc) · 3.83 KB

README.md

File metadata and controls

50 lines (39 loc) · 3.83 KB

Automated development workstation set up

To avoid the hassle of re-installing all apps manually, I decided to maintain the development workstation set up using Ansible.

The general idea is to install as many packages as possible with Chocolatey which allows easy updates. The Windows should only keep UI applications and utilities required for daily routines. With the release of WSL2, most non-interactive tools I use are in a Ubuntu 20.x based WSL2 distro.

Note: this repo contains set up for what I need, it's not aimed to create a generic set up for any developer. Fork the repo for customizations.

What's in the box

The scripts and playbooks:

  • Enable WSL2 along with all required dependencies
  • Install basic apps - check the yml file for full list (chrome, 7-zip etc.)
  • Install development tools like VS Code, Docker desktop or Visual Studio - check the yml file for full list
  • Set up Powerline shell compatible fonts so you can use it in Windows Terminal or via wsl.exe
  • Set up YubiKey relay so that you can use your YubiKey as:
    • an SSH key from WSL to connect to remote machines
    • an SSH key from WSL to connect to remote git origins
    • a GPG key for encryption from both WSL and Windows (via GPG4Win)
    • sign git commits when commiting from Windows via GitKraken
  • Install SDKs for Golang, Python (implied by Ansible), .NET Core and NodeJS (all in WSL)

Set up guide

Note: this repository assumes you are running Windows 10 1903 or later running on x64 architecture.

  1. Prepare Windows using the Set-ExecutionPolicy Bypass -Scope Process; .\Init-Windows.ps1 Powershell command. Run the script with admin privileges. Some of the features require computer restart, keep rerunning the script after each restart until you see a message saying the script is finished. The script:
    • Enables Hyper-V
    • Enables WSL
    • Downloads and creates an Ubuntu 20.04 LTS distro
    • Enables Windows Remoting (so that Ansible playbook used in subsequent steps can talk to Windows host). Feel free to disable the remoting after the configuration has been completed.
  2. Prepare WSL distribution using the sudo ./Init-Ubuntu.sh bash command. The script must be run with sudo privileges. (the script adds Ansible repository and installs latest version of Ansible). If you have an older version of Ansible already installed, make sure you uninstall it first.
  3. Install dependencies with ansible-galaxy install -r requirements.yml
  4. Apply the Windows playbook using ansible-playbook -i inventory.yml -u <username> -k setup-win.yml
    • Replace <username> for your Windows username. If it's a domain account, enter it in user@domain format.
    • Ansible will ask you for SSH Password which is a bit unfortunate phrasing, it's actually asking for your Windows password.
    • If you get error that ntlm credentials are not allowed, you need to use different authentication technology. Check Ansible docs for other options.
    • The playbook may restart the pc without prior notice. If it does, repeat applying this playbook after the restart until the whole playbook is finished.
  5. Apply the Linux playbook using ansible-playbook -i inventory.yml -K setup-wsl.yml
    • Ansible will ask you for password, this is to allow assuming sudo (required to install packages)

Development

Changes should be testing using an Azure VM which supports nested virtualization with Windows 11 Pro/Enterprise:

  • Provision VM
  • Copy repo/developed branch (e.g. download as zip from GitHub)
  • Follow the guide above

Testing YubiKey set up

To pass access to YubiKey to remote machine, don't forget to add passthrough to Plug'n'Play devices (the checkbox devices I plug in later) when connecting via RDP.