This repository contains useful scripts to set up a Linux development machine. They assume Ubuntu 18.04 or later, and have been tested with the following OSes:
Note: The scripts have been updated to support Ubuntu on WSL ("Windows Subsystem for Linux"), though some features require WSL 2.
Other Ubuntu variants may work (like Mint) but they have not been tested. Non-Ubuntu variants are unsupported (with no
intention of supporting them). Similarly, text shell for customization work is bash
, and UI shell customization work is for
Gnome; other shells are left as an exercise to the reader.
The purpose here is to document what I use for my personal Linux-based development. You will likely want to make changes to my customizations, including adding/removing software, choosing different defaults, etc. While you can make those changes locally, if you plan to use these scripts long-term, it will likely be more beneficial for you if you fork this project so you can preserve your changes and easily merge newer versions of these scripts.
You can get Teams to be fully functional inside of Chrome (and only Chrome, not Chromium) by installing these two extensions. The Ansible scripts do not install these extensions because Google has prohibited extension installation through any mechanism other than the interactive UI (to help prevent malware attacks against Chrome that install extensions).
Once these two extensions are installed, you should have full functionality inside Teams, including audio calls, video calls, and screen sharing. Note that unlike on Windows, screen sharing cannot be limited to a single monitor; you only get "all screens" or "single application" sharing. This appears to be a limitation of the functionality exposed by Chrome on Linux for screen capture.
-
Make sure you're up to date:
$ sudo apt update $ sudo apt -y upgrade
-
Install Ansible:
$ sudo apt -y install ansible
-
If you want to clone this Git repo, you should also install Git (
sudo apt -y install git
). These scripts will install it for you if you brought these files along in some other way.
Before running the scripts, please review _all.yaml
and _all_no_customization.yaml
, and comment out software you don't
want installed. In particular, most folders contain customization.yaml
files which tend to contain my personal opinions on
customizations; feel free to comment out sections of those files, or ignore them entirely.
To run the setup:
$ ansible-playbook -K _all.yaml
You can also run individual files if you'd prefer to take more control over what's executed.
You will be prompted for your sudo password. Most of the operations performed by these scripts require root access.
Since core OS packages are upgraded, it is safest to reboot the PC/VM after running these scripts. At a bare minimum, many UI shell customizations done here will require you to log out and log back in.