Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/andrewconnell/osx-install
My setup steps, scripts & settings for configuring my MacOS.
https://github.com/andrewconnell/osx-install
Last synced: 6 days ago
JSON representation
My setup steps, scripts & settings for configuring my MacOS.
- Host: GitHub
- URL: https://github.com/andrewconnell/osx-install
- Owner: andrewconnell
- Created: 2015-08-23T20:05:49.000Z (over 9 years ago)
- Default Branch: master
- Last Pushed: 2025-01-04T12:08:07.000Z (about 2 months ago)
- Last Synced: 2025-02-04T23:38:57.870Z (14 days ago)
- Language: Shell
- Homepage:
- Size: 20 MB
- Stars: 106
- Watchers: 10
- Forks: 29
- Open Issues: 2
-
Metadata Files:
- Readme: readme.md
Awesome Lists containing this project
README
# MacOS Buildout
This repo acts as a log for my buildout of my laptop. As I add stuff or change settings, I log it here so pave & restores can go quickly in the future. Feel free to fork & customize to your liking.
More background info: [BLOG: Rapid Complete Install / Reinstall OS X Like a Champ in Three-ish Hours](http://www.andrewconnell.com/blog/rapid-complete-install-reinstall-os-x-like-a-champ-in-three-ish-hours)
## Before Paving, document current config
Do the following before paving the partition. This is to get the way I have things configured in the dock & menu bar back the way I want them.
- Set up timestamped backup folder, **{{PRIVATE_BACKUP}}**, OneDrive to copy things
- Screenshot all installed apps
- Screenshot OneDrive sync'd doclib's from MS Teams & save => **{{PRIVATE_BACKUP}}**
- XCOPY the following => **{{PRIVATE_BACKUP}}**
> **NOTE:** many of the hidden files & folders are copied as "dot-files"- `~/_play`
- `~/.gitconfig`
- `~/.gitmessage`
- `~/.npmrc`
- `~/.ssh`
- `~/.yarnrc`
- `~/.zsh`
- `~/.zprofile`
- `~/.zshenv`
- `~/.zshrc`
- `~/Movies`
- `~/voitanos-workspace`
- *review other folders in the root*
- Dev
- Dump list of all repos in `~/repos` => **{{PRIVATE_BACKUP}}/{{BACKUPDATE}}**
- Clone all repos (+ upstream remotes) using this script: [scripts/repo-gen-clone-script.zsh](./repo-gen-clone-script.zsh)
- iStat Menu
- backup settings => **{{PRIVATE_BACKUP}}/iStat Menus Settings.ismp**
- Node
- refresh NPM global package install list: **./scripts/npm-install-packages-lts-*.zsh**```console
npm list -g --depth=0
```- Copy virtual machines => external storage
- Postman
- export all collections & environments => **{{PRIVATE_BACKUP}}/Postman-backup.zip**
- Screenflow
- log batch export settings to **[./AppSettings/Screenflow](./AppSettings/Screenflow)**
- Stream Deck
- export & save Stream Deck profiles => **{{PRIVATE_BACKUP}}/Stream Deck - {{..}}.streamDeckProfilesBackup**
- Visual Studio Code
- refresh installed extensions install list: **[./scripts/vscode-ext-install.zsh](./scripts/vscode-ext-install.zsh)**```console
code --list-extensions
```- backup snippets & user settings to **{{PRIVATE_BACKUP}}/VisualStudioCode**
- user settings: `~/Library/Application Support/Code/User`### MacOS & System
- have a current Apple TimeMachine backup job finished
- screenshots of Finder settingsdata:image/s3,"s3://crabby-images/f2db7/f2db7479c5ff6486d6b66ea0f6e72753416ff762" alt=""
- screenshot MacOS dock
data:image/s3,"s3://crabby-images/d2600/d2600be0987fd81bb9624f0a97876d2479f91c51" alt=""
- screenshot expanded Bartender MacOS Menu Bar
data:image/s3,"s3://crabby-images/3dcf7/3dcf73c5c093b943b2eeebd5ae9180370873742b" alt=""
### Installed apps
- get list of all apps installed via Homebrew:
```console
brew leaves
```### Adobe Creative Cloud
- Launch each app and sync settings (PUSH) for:
- Media Encoder
- Photoshop
- Premiere Pro
- Photoshop:
- export saved actions: **[./AppSettings/AdobeCreativeCloud/Photoshop](./AppSettings/AdobeCreativeCloud/Photoshop)**
- Premiere Pro:
- export custom presets: **[./AppSettings/AdobeCreativeCloud/PremierePro](./AppSettings/AdobeCreativeCloud/PremierPro)**
- Jump Desktop
- export list of VMs => **{{PRIVATE_BACKUP}}**
- Mac App Store apps
- refresh list installed MacOS apps: **[./scripts/macos-install.zsh](./scripts/macos-install.zsh)**```console
mas list
```## Pave partition
1. restart with ⌘+R
1. go to **Disk Utility**
1. select the main drive, then select **Erase** > **Erase Volume Group**
1. create new ADFS volume
1. install MacOS via internet## Install apps
The following installs & configuration should be done to setup automated installs.
### If installing on Apple Silicon
Install Rosetta 2
```console
sudo softwareupdate --install-rosetta
```### Homebrew & Homebrew Cask
Install [Homebrew](http://brew.sh/) for automated installs & updates.
```console
/bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)"
```> [!TIP]
> If get error about `zsh compinit: insecure directories, run compaudit for list.`, first try to run the following to see if it fixes it:
>
> ```console
> chmod go-w '/opt/homebrew/share'
> chmod -R go-w '/opt/homebrew/share/zsh'
> ```
>
> ... if the issue persists, do what it says:
>
> `$ compaudit`
>
> For the folder(s) returned, fix it with:
>
> `$ sudo chmod -R 755 {PATH}`### Install fonts
```console
curl -L https://raw.githubusercontent.com/andrewconnell/osx-install/master/scripts/core-fonts.zsh | zsh
```### Install & setup console
Installs ideal shell, prompt, and terminals
> **NOTE**: Monitor the terminal for password prompts & errors/warnings.
1. run following to install cores
```console
curl -L https://raw.githubusercontent.com/andrewconnell/osx-install/master/scripts/core-install.zsh | zsh
```1. copy the **[dotfiles & folders](./dotfiles/)** (overwriting existing) into home folder
1. search for any `{{{REPLACE_THIS}}}` and replace with correct values
1. setup SSH with 1Password for `.gitconfig`
- **1Password > Settings > Developer** & select all options### Install apps via Homebrew: `homebrew-install-apps.zsh`
Install apps using Homebrew.
> **NOTE**: Monitor the terminal for password prompts & errors/warnings.
run following to install cores
```console
curl -L https://raw.githubusercontent.com/andrewconnell/osx-install/master/scripts/homebrew-install-apps.zsh | zsh
```Pay attention for extra installs & steps at the end.
### Setup Warp theme
- Copy Tailwind theme from [`./dotfiles/.warp`](./dotfiles/.warp) > `~/`
- Launch Warp & login
- Settings > Appearance > Theme, select Dark
- Find and select **Tailwind**### Install Mac App Store apps: `macos-install.zsh`
Install apps from the Apple App Store.
```console
curl -L https://raw.githubusercontent.com/andrewconnell/osx-install/master/scripts/macos-install.zsh | zsh
```### Manual Installs
- Amphetamine Enhancer - https://github.com/x74353/Amphetamine-Enhancer
- [Sophos Home A/V](https://home.sophos.com)## Configure apps
Three step process:
1. Get OneDrive syncing to get access to backups, settings (in OneDrive), licenses & passwords in password manager
1. Login, license, install, & configure remaining apps### Configure core apps to acquire backups, licenses & passwords
- login to the following apps
- Google Chrome
- *do this first & login to password manager to get licenses*
- OneDrive
- *do this to get sync running... contains backup files collected before pave*
- Visual Studio Code
- install extensions collected before pave:```console
curl -L https://raw.githubusercontent.com/andrewconnell/osx-install/master/scripts/vscode-ext-install.zsh | zsh
```- copy snippets & settings:
- from **[./AppSettings/VisualStudioCode](./AppSettings/VisualStudioCode)**
- to `~/Library/Application Support/Code/User`
- apply licenses to extensions Quokka & Wallaby### Setup SSH
- setup SSH keys
- copy backed up `./.ssh` keys from **{{PRIVATE_BACKUP}}** => `./.ssh`
- configure SSH keys```console
# set permission to make my keys private
sudo chmod 400 ~/.ssh/id_rsa# configure 'config' folder permissions
sudo chmod 600 ~/.ssh/config# add key to SSH agent
# + enter passphrase from password manager when prompted
ssh-add ~/.ssh/id_rsa# add to keychain
ssh-add -K
```### Configure Installed Apps
- Alfred
- Activate power pack within app settings
- **Preferences > Advanced**: Syncing - set to **./{{PRIVATE-BACKUP}}/Alfred**
- Amphetaminedata:image/s3,"s3://crabby-images/8cf1d/8cf1dfd1ff7a2c2f30b40eb377461878b83d6524" alt=""
data:image/s3,"s3://crabby-images/0ff0b/0ff0b1a8b1ee3aeff6b29e6fa051683f5f7111ad" alt=""
data:image/s3,"s3://crabby-images/648de/648deb645336482d2dca2c4dd52797c99ad1413d" alt=""
data:image/s3,"s3://crabby-images/e24fb/e24fb1f3e5debd814c880a1b691eb1d077bc781d" alt=""
data:image/s3,"s3://crabby-images/de010/de01048589cf356354ba6227fbbeed655d3ac4e7" alt=""
- iStat Settings
- license & restore settings: [./AppSettings/iStat Menus Settings.ismp](./AppSettings/iStat%20Menus%20Settings.ismp)
- Bartender
- License & configure:data:image/s3,"s3://crabby-images/3dcf7/3dcf73c5c093b943b2eeebd5ae9180370873742b" alt=""
- Control Center
- Open & configure to launch at login
- Divvy
- import shortcuts by opening Safari / Firefox & enter the url in [./AppSettings/divvy.md](./AppSettings/divvy.md)data:image/s3,"s3://crabby-images/85fe9/85fe90c8bf6e2a1ac656ce0fb76f26f03f6d0028" alt=""
- Jump Desktop
- import the machines from export before pave
- Microsoft Outlookdata:image/s3,"s3://crabby-images/e36fd/e36fdba83a14538ecba213c6b4a1a798295a2994" alt=""
data:image/s3,"s3://crabby-images/720db/720db73732fad61aa36d34a4d1da030e0f81c558" alt=""
data:image/s3,"s3://crabby-images/4dc1b/4dc1bb141724b507e19a0cf0ed4062237b074519" alt=""
data:image/s3,"s3://crabby-images/7d93b/7d93b4c908211c4c7a615d91cdc419cf0fbd7bfe" alt=""
data:image/s3,"s3://crabby-images/b75f8/b75f8ba3e68c5c2b023ac362299c50ddc971494c" alt=""
data:image/s3,"s3://crabby-images/b4acc/b4accb37f553e1cd69f6a4c7b0e39e2e82c7dc70" alt=""
data:image/s3,"s3://crabby-images/f9fbd/f9fbdec50780c274733fba75ad3be94119b35078" alt=""
- Signature
- get signatures from previous "sends"- Microsoft Teams
- Parcel
- Screenflow
- license
- create custom batch export profile
- Slack
- Steam
- Launch & login
- Disable auto login: **Preferences > Interface > [uncheck] Run Steam with my computer starts**
- Stream Deck
- restore profiles
- install plugins from Stream Deck store:
- Home Assistant
- Phillips Hue
- VLC## Additional downloads & installs: `scripted-installs.zsh`
```console
curl -L https://raw.githubusercontent.com/andrewconnell/osx-install/master/scripts/scripted-installs.zsh | zsh
```### Install custom fonts
- Open `~/Library/Fonts`
- For the following folders, select all fonts files, open in macOS' **Font Book**, & install them:
- AC Handwriting
- Omnes
- Segoe UI MDL2### Creative Cloud installs
- Install apps:
- Acrobat DC
- After Effects
- Audition
- Bridge
- Illustrator
- Media Encoder
- Photoshop
- Premiere Pro
- Import settings from the pre-pave section above on [Adobe CC apps](#adobe-creative-cloud)
- Manually install **[aescripts + aeplugins](https://aescripts.com/)** manager, login & install plugins## Install Node
Manage node installs using NVM... this lets me test different versions of node as well as avoid issue with having to use `sudo` when installing packages globally.
```console
mkdir ~/.nvm
```### Install & configure Node LTS & stable versions
> [!CAUTION]
> The following script doesn't work. Something is causing `nvm` to not be seen as a valid comment.
>
> Instead, copy the blocks of code from the following installer script file and manually run in the console.This script installs multiple Node versions:
```console
curl -L https://raw.githubusercontent.com/andrewconnell/osx-install/master/scripts/node-install.zsh | zsh
```## Post installation & configuration checks
### Update Homebrew, Homebrew Cask & purge installs
```console
brew doctor
brew update
brew cleanup
```### Setup git
> NOTE: This might already be done by copying the hidden **~./.gitconfig**.
```console
git config --global user.name "Andrew Connell"
git config --global user.email
git config --global credential.helper osxkeychain
# set VSCode as commit message editor & merge tool
git config --global core.editor "code -w"
git config --global merge.tool code
```### MacOS Tweaks
- Desktop (*change these settings by right-click desktop & pick **Show View Options***)
data:image/s3,"s3://crabby-images/69374/69374d87a3c348fc9ee39604226bfbc99089e7aa" alt=""
- System Preferences
- Accessibilitydata:image/s3,"s3://crabby-images/52a96/52a969ee1d34cabd6924843c8fbd3a0782dec90c" alt=""
- Dock
- settings: **System Preferences > Dock**data:image/s3,"s3://crabby-images/e44a6/e44a65c68150289cb9b60e8d41411715fd44ddaa" alt=""
- update dock to the backup image
data:image/s3,"s3://crabby-images/d2600/d2600be0987fd81bb9624f0a97876d2479f91c51" alt=""
- General
data:image/s3,"s3://crabby-images/a319b/a319b02654cd7ba56d7e89f279a8ec80647cdcdb" alt=""
- Keyboard
data:image/s3,"s3://crabby-images/aa942/aa942e8762c4bf790a48e78eb90d8ec9a034fdf8" alt=""
- Shortcuts - uncheck options for Spotlight, then manually setup activation keystroke for Alfred to CMD+SPACE
data:image/s3,"s3://crabby-images/a7bd5/a7bd54e30bdc2dd36f64f87bf3038c64cba02276" alt=""
- Mission Control
data:image/s3,"s3://crabby-images/22f2d/22f2dff2676689e26ee6132b3b765aed34be2a2c" alt=""
- Internet Accounts
data:image/s3,"s3://crabby-images/1db9f/1db9f1e194745153d0fbea91a52864dd70692394" alt=""
- Printers
- install / add printers
- Security > Privacy
- Activate & enable where necessary
- Users & Groups / Login Itemsdata:image/s3,"s3://crabby-images/06e7f/06e7f29b14583a1f6e0841b73f6e559ac1aa5642" alt=""
### Data Restore
- Clone select repositories from github => `~/repos`
### Setup TimeMachine Backups
Run first backups.
## Ongoing... HOWTO Keep Things Updated
to keep Homebrew installed things update, do this:
```console
brew update # download app updated formulas
brew outdated # what's old?
brew upgrade # upgrade everything locally
# list all brew casks installed & their versions
brew cask outdated
brew cask upgrade
# cleanup everything
brew cleanup
```update MacOS apps:
```console
mas outdated # what's old
mas upgrade # upgrade everything
```update MacOS: [ref](https://developer.apple.com/legacy/library/documentation/Darwin/Reference/ManPages/man8/softwareupdate.8.html)
```console
softwareupdate --list
# install things based on the name returned using
sudo softwareupdate --install [name listed]
```