Provision macOS environments through code
- macOS
- a (moderately) up-to-date copy of Git.
- a compatible set of configuration files
- Create a local clone of the Place repository:
git clone "git@github.com:operatehappy/place.git" "${HOME}/.place"
- Create an alias for
place
in your Bash configuration (usually.bashrc
or.bash_profile
):
alias place='make --file="${HOME}/.place/Makefile" --directory="${HOME}/.place/"'
- Reload your Bash configuration and verify
place
is available
After reloading your Bash configuration, verify everything works by running place overview
:
π Place
CONFIGURATION
brewfile: /Users/operatehappy/.Brewfile
base directory: /Users/operatehappy/.cache/place
user directory: /Users/operatehappy/.config/place
- Install Xcode CLI Tools, Brew and Ansible:
place install
The Xcode CLI Tools, brew
, and ansible
can also be installed separately:
place xcode
to install Xcode CLI Toolsplace brew
to install Brewplace ansible
to install Ansible
- Install Brew Packages, Taps, Casks and App Store applications (using
mas
) defined in yourBrewfile
:
place brewfile
Brew-managed packages, applications, and casks can be managed through:
place brew-update
to update Brewplace brew-upgrade
to upgrade Brew packagesplace brew-upgrade-casks
to update Brew Casksplace brew-outdated
to list outdated Brew packagesplace brew-clean
to clean up cached Brew files
In addition to Brewfile
support, Place also can install gem
, npm
, and pip
packages as well as Visual Studio Code (or VSCodium extensions, respectively:
place gem
for Ruby Gems, defined in~/.config/place/ruby-gems.yml
place npm
for NPM packages, defined in~/.config/place/npm-packages.yml
place pip
for pip packages, defined in~/.config/place/pip-packages.yml
place code-extensions
for Visual Studio Code (or VSCodium) extensions, defined in~/.VisualStudioCodeExtensions
Place supports rapidly setting large amounts of macOS Defaults:
place defaults
for Defaults defined in~/.config/place/macos-defaults.yml
A default configuration for macos-defaults.yml
could look like this:
---
macos_defaults:
- # auto-hide Dock
domain: "com.apple.dock"
key: "autohide"
type: "bool"
value: "true"
state: present
macos_defaults_targets:
- Dock
Each Default is a child item of macos_defaults
and must contain at least:
domain
key
value
The keys subkey
, type
, and state
are optional
Any applications that require a restart for Defaults to be applied can be listed in macos_defaults_targets
.
Place supports syncing your (remote) Dotfiles:
place dotfiles
for Dotfiles configuration defined in~/.config/place/dotfiles.yml
A default configuration for dotfiles.yml
could look like this:
---
repository: "git@github.com:ksatirli/dotfiles.git"
source_directory: "{{ lookup('env','HOME') }}/.dotfiles"
destination_directory: "{{ lookup('env','HOME') }}/"
excludes_file: "{{ lookup('env','HOME') }}/.dotfiles/.config/rsync/excludes"
Internally, Place will git clone
the repository specified in dotfiles.yml
and then rsync
any files in source_directory
with destination_directory
.
-
Place has a large number of additional options available, these can be found through
place help
-
Place supports in-line configuration for the three base variables
brewfile
,base-directory
anduser-directory
place brewfile=~/.alternate-Brewfile brewfile
to set theBrewfile
location to~/.alternate-Brewfile
place base-directory=~/.place-home install
to set the base directory to~/.place-home
place user-directory=~/.place-user install
to set the user directory to~/.place-user
The options for base-directory
and user-directory
are ephemeral and need to be set with every Place CLI option (e.g.: install
, brew
, ansible
etc.)
-
Place now defaults Brew Cask Update jobs to utilize the
--no-quarantine
flag as anyBrewfile
supplied arguments are chosen by the user and should therefore be trustworthy- These options can be overridden by passing empty
brew-cask-opts
andbrew-cu-opts
arguments to Place
- These options can be overridden by passing empty
-
Additional configuration options can be found in make/CONFIG.mk
This module is maintained by the contributors listed on GitHub.
Development of this module was sponsored by Operate Happy.
Licensed under the Apache License, Version 2.0 (the "License").
You may obtain a copy of the License at apache.org/licenses/LICENSE-2.0.
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" basis, without WARRANTIES or conditions of any kind, either express or implied.
See the License for the specific language governing permissions and limitations under the License.