Dorothy is a dotfile ecosystem featuring:
- π seamless support for Bash, Zsh, Fish, Nu, Xonsh, Elvish, Dash, KSH
- π©» seamless support for multiple operating systems and architectures
- π©βπ» seamless support for your favorite terminal and GUI editors
- π¦Ύ automatic configuration of your environment variables for what you have installed on your system
- π¦ automatic installation and updating of your specified packages
- π³ automatic Git, SSH, and GPG configuration based on what your system supports and your configuration
- βοΈ hundreds of commands to improve your productivity
- βοΈ completely extensible and configurable with your own user repository
- π¦ΈββοΈ all this together, allows you to go from zero to hero within minutes, instead of days, on a brand new machine
Watch the 2023 November Presentation to see what Dorothy can do!
Operating System | Architecture | Support |
---|---|---|
π macOS | π Apple Silicon (ARM64) | π Daily Driver |
π macOS | π Apple on Intel (x86_64) | π Daily Driver, π€ CI |
π macOS | π Apple Silicon with HOMEBREW_ARCH="x86_64" |
π Monthly Driver |
πͺ Windows 10/11 WSL2 Ubuntu | π Intel/AMD (x86_64) | π Daily Driver |
π Raspberry Pi OS with Desktop | π Raspberry Pi 4/400/5 (ARM64) | π Daily Driver |
π Raspberry Pi OS Lite | π Raspberry Pi 4/400/5 (ARM64) | π Monthly Driver |
βοΈ Ubuntu Desktop | π Raspberry Pi 4/400/5 (ARM64) | π Daily Driver |
βοΈ Ubuntu Desktop | π Intel/AMD (x86_64) | π Daily Driver |
βοΈ Ubuntu Server | π Raspberry Pi 4/400/5 (ARM64) | π Daily Driver |
βοΈ Ubuntu Server | π Intel/AMD (x86_64) | π Daily Driver, π€ CI |
βοΈ Ubuntu Server | 5οΈβ£ StarFiveβs VisionFive (RISC-V) | π Monthly Driver |
β² Manjaro / Arch | π Intel/AMD (x86_64) | π Daily Driver, π€ CI |
β Fedora Workstation | π Intel/AMD (x84_64) | π Monthly Driver, π€ CI |
π¦ OpenSUSE Leap & Tumbleweed | π Intel/AMD (x84_64) | π Monthly Driver, π€ CI |
β° Alpine | π Intel/AMD (x84_64) | π Monthly Driver, π€ CI |
β° Alpine | π Apple Silicon (ARM64) | π Monthly Driver |
π Kali | π Intel/AMD (x84_64) | π Monthly Driver, π€ CI |
Other platforms may or may not be supported. Mageia, Nix, Gentoo are unsupported.
Dorothy has intelligent dependency management with its own setup-util
command and setup-util-*
ecosystem, that automates and assists dependency and package availability across platforms, architectures, and package systems.
Dependencies that are required to achieve your intended goal, will have their installations initiated correctly. Dependencies that are not required, but provide a superior experience, will have their installations attempted but if an installation fails or is unavailable, the command will not dazzle but will still execute successfully to satisfaction. Sometimes commands can go an extra mile if a dependency is detected, such as for performance or gathering additional optional information, however, if an already suitable dependency is already available then the suitable installed dependency will be used. This enables Dorothy to provide extreme robustness and superiority of its experience.
For instance, installing curl with Dorothy is as easy as executing setup-util-curl
, or directly by setup-util --cli=curl APK=curl APT=curl AUR=curl BREW=curl RPM=curl WINGET=cURL ZYPPER=curl
. If you want to make it optional, add --optional
. If you want to write a command that prefers curl
but also supports wget
if curl isn't present, see Dorothy's fetch
command, or for something even more powerful, see Dorothy's down
command.
Important
To even initiate Dorothy, some prerequisite dependencies are required:
macOS:
xcode-select --install
Windows 10/11:
# [Install WSL.](https://learn.microsoft.com/en-au/windows/wsl/install)
wsl --install
wsl --set-default-version 2
# note that [wsl --version] does not report WSL2, you need to do [wsl -l -v]
Ubuntu / Debian / Kali:
sudo apt-get update
sudo apt-get install bash curl
Fedora:
dnf check-update
dnf --refresh --best install bash curl
OpenSUSE / SUSE:
zypper --gpg-auto-import-keys refresh
zypper install bash curl
Alpine:
doas apk update
doas apk add bash curl
Manjaro:
pamac install bash curl
Arch:
pacman-key --init
pacman --refresh --sync --needed bash curl
Void:
xbps-install --sync --update xbps
xbps-install --sync bash curl
Now that the prerequisites are installed, Dorothy's intelligent dependency management will be enabled, so you can skip this section. Dorothy's complete requisites for its core experience are as follows:
bash
,curl
: required for initiationgrep
,git
,awk
: required for installationjq
,deno
: required for advanced configuration and regular expression processing
If the automated installation of any failed, post an issue including details of your environment, and use their links for alternative installation methods. If you are downloading their binaries straight from GitHub, you can unzip with tar -xvf <archive>
, make a discoverable binary directory with mkdir -p ~/.local/bin
, move the binary there with mv <bin> ~/.local/bin
, and make the binaries executable with chmod +x ~/.local/bin/*
.
Tip
You can trial Dorothy commands without configuring your shell:
To run a specific command in/from the Dorothy environment, enter the following, swapping out everything after the double-dash (--
) with whatever command to run:
bash -ic "$(curl -fsSL https://dorothy.bevry.me/run)" -- echo-verbose -- a b c
# if your shell doesn't recognize any of the above syntax, run `bash -i` then try again
To run multiple commands in/from a Dorothy-configured REPL, enter the following line by line:
bash -ic "$(curl -fsSL https://dorothy.bevry.me/repl)"
# if your shell doesn't recognize any of the above syntax, run `bash -i` then try again
# now you can run whatever and how many commands as you'd like, such as:
echo-verbose -- a b c
echo-style --success=awesome
# once you are done, exit the trial environment
exit
Important
To install Dorothy enter the following into your favorite terminal application:
bash -ic "$(curl -fsSL https://dorothy.bevry.me/install)"
# if your shell doesn't recognize any of the above syntax, run `bash -i` then try again
During installation, Dorothy will ask you to create a repository to store your user configuration, such as a dotfiles
repository. If you already have a dotfiles repository, you can use that, or make another.
Verify the installation worked by selecting a theme for Dorothy by running:
# you must open a new terminal instance first
dorothy theme
# then open a new terminal
To select your login shell, run setup-shell
.
If packages are failing to install, go back to the "Prerequisites" section.
If your shell doesn't recognize any of the Dorothy commands (you get a command not found error, or an undefined/unbound variable error), then it could be that:
- Your shell is not running as a login shell. Verify that your Terminal is running the shell as a login shell.
- Dorothy did not configure itself for the shell you use. Re-run the Dorothy installation process, and be sure to configure Dorothy for your shell.
- Your login shell is not one of the Dorothy supported shells. Create an issue requesting support for your shell.
If you see unrecognised symbols, you probably require fonts. Once Dorothy is loaded, run setup-util-noto-emoji
which installs Noto Emoji, a font for enabling emojis inside your terminal. For rendering glyphs, run setup-util-nerd-fonts
which will prompt you for which Nerd Font to install. You may need to update your terminal preferences to leverage these installed fonts.
Dorothy installs itself to $DOROTHY
, which defaults to the XDG location of ~/.local/share/dorothy
, and consists of the following:
commands
directory contains executable commands of super-stable quality, they are actively used within the Dorothy core and by the users of Dorothy.commands.beta
directory contains executable commands of beta quality, these are commands that require more usage or possible breaking changes before promotion tocommands
.config
directory contains default configurationsources
directory contains scripts that are loaded into the shell environmentthemes
directory contains themes that you can select via theDOROTHY_THEME
environment variableuser
directory is your own github repository for your custom configuration
For each shell that you configured during the Dorothy installation (can be reconfigured via the dorothy install
command), the configured shell performs the following steps when you open a new shell instance via your terminal:
-
The shell loads Dorothy's initialization script:
-
The initialization script will:
-
Ensure the
DOROTHY
environment variable is set to the location of the Dorothy installation. -
If a login shell, it loads our login script
sources/login.(bash|dash|elv|fish|ksh|nu|xsh|zsh)
, which will:-
Apply any configuration changes necessary for that login shell
-
Load our environment script
sources/environment.(bash|dash|elv|fish|ksh|nu|xsh|zsh)
, which will:- Invoke
commands/setup-environment-commands
which determines and applies all necessary environment configuration changes to the shell. It loads youruser/config(.local)/environment.bash
configuration script for your own custom environment configuration that will be applied to all your login shells.
- Invoke
-
-
If a login and interactive shell, it loads our interactive script
sources/interactive.(bash|dash|elv|fish|ksh|nu|xsh|zsh)
, which will:- Load your own
user/config(.local)/interactive.(sh|bash|dash|elv|fish|ksh|nu|xsh|zsh)
configuration script for your own interactive login shell configuration.- Elvish will only load
interactive.elv
if it exists. - Fish will load
interactive.fish
if it exists, otherwise it will loadinteractive.sh
. - Nu will only load
interactive.nu
and it must exist. - Xonsh will only load
interactive.xsh
if it exists. - POSIX shells (Bash, Zsh, Dash, KSH, etc) will load their
interactive.(bash|zsh|...etc)
file if it exists, otherwise they will loadinteractive.sh
if exists.
- Elvish will only load
- Load any common alias and function utilities.
- Load our theme configuration.
- Load our ssh configuration.
- Load our autocomplete configuration.
- Load your own
-
This is the foundation that enables Dorothy's hundreds of commands to work across hundreds of machines, across dozens of operating system and shell combinations, seamlessly.
Your user configuration goes to the XDG location of ~/.local/config/dorothy
which Dorothy symlinks to ~/.local/share/dorothy/user
, your user configuration consists of the following:
commands
directory, for public commandscommands.local
directory, for private commands (git ignored by default)config
directory, for public configurationconfig.local
directory, for private configuration (git ignored by default)
The order of preference within Dorothy is (commands|config).local
first, then (commands|config)
, then Dorothy's own (commands|config)
then everything else.
You can find the various configuration files that are available to you by browsing Dorothy's default config
directory.
Use these sources to find inspiration for your own user commands and configuration.
- Dorothy's
commands
directory for super-stable commands with up to date conventions. - Dorothy's
commands.beta
directory for beta-quality commands with possibly outdated conventions. - Dorothy's
docs
directory containing tips and tricks for Dorothy, and various shells, such as enabling private user configurations, and the manual to assisted philosophy of Dorothy - Dorothy User Configurations:
- @balupton / dotfiles: uses Fish as login shell, plenty of Bash commands
- @molleweide / dotfiles: uses Zsh as login shell, plenty of Bash commands, kmonad user
- @jondpenton / dotfiles: uses Nu as login shell, plenty of Nu commands
- See more Dorothy User Configurations
- To feature your own Dorothy User Configuration, send a pull request.
After installing Dorothy, there will now a plethora of commands available to you. You can invoke any stable command with --help
to learn more about it. The most prominent commands are noted below.
Stable commands:
-
setup-system install
correctly setup your system to your prompted preferencessetup-system update
correctly update your system to your existing preferences
This is done via these commands:
-
setup-linux
correctly setup your Linux system, and its various packaging systems, as desired -
setup-mac
correctly setup your macOS system, including its homebrew and Mac App Store installations, as desired -
setup-bin
correctly setup available CLI utilities from installed GUI Applications -
setup-git
correctly setup Git on your system, including your profile, SSH, GPG, and 1Password configurations, as desired.Related commands:
gpg-helper
interact with your GPG keysssh-helper
interact with your SSH keys
-
setup-go
correctly setup GoLang on your system if desired or if required for your desired packages -
setup-node
correctly setup Node.js on your system if desired or if required for your desired packages -
setup-python
correctly setup Python on your system if desired or if required for your desired packages -
setup-ruby
correctly setup Ruby on your system if desired or if required for your desired packages -
setup-rust
correctly setup Rust on your system if desired or if required for your desired packages -
setup-utils
correctly setup your selectedsetup-util-*
utilities as desired
-
setup-util
is an intelligent wrapper around every package system, allowing a cross-compatible way to install, upgrade, and uninstall utilities.It is used by the hundreds of
setup-util-*
commands, which enable installing a utility as easy as invokingsetup-util-<utility>
If you don't know which command you need to call, you can use
get-installer
to get which command you will need to invoke to install a utility/binary/application. -
setup-shell
correctly configure your desired shell to be your default shell.By default, your terminal application will use the login shell configured for the system, as well as maintain a whitelist of available shells that can function as login shells.
-
edit
quickly open a file in your preferred editor, respecting terminal, SSH, and desktop environments. -
down
download a file with the best available utility on your computer. -
github-download
download files from GitHub without the tedium. -
secret
stops you from leaking your env secrets to the world when a malicious program sends your shell environment variables to a remote server. Instead,secret
will use 1Password to securely expose your secrets to just the command that needs them. Specifically:- secrets are fetched directly from 1Password, with a short lived session
- secrets are cached securely for speed and convenience, only root/sudo has access to the cache (cache can be made optional if you want)
- secrets are not added to the global environment, only the secrets that are desired for the command are loaded for the command's environment only
-
setup-dns
correctly configures your systems DNS to your preferencesA large security concern these days of using the internet, is the leaking, and potential of modification of your DNS queries. A DNS query is what turns
google.com
to say172.217.167.110
. With un-encrypted DNS (the default), your ISP, or say that public Wifi provider, can intercept these queries to find out what websites you are visiting, and they can even rewrite these queries, to direct you elsewhere. This is how many public Wifi providers offer their service for free, by selling the data they collect on you, or worse.The solution to this is encrypted DNS. Some VPN providers already include it within their service, however most don't. And if you have encrypted DNS, then you get the benefits of preventing eavesdropping without the need for expensive VPN, and the risk of your VPN provider eavesdropping on you.
Dorothy supports configuring your DNS to encrypted DNS via the
setup-dns
command, which includes installation and configuration for any of these:- AdGuard Home
- Cloudflared
- DNSCrypt
Related commands:
flush-dns
lets you easily flush your DNS anytime, any system.setup-hosts
lets you easily select from a variety of HOSTS files for security and privacy, while maintaining your customizations.
-
mount-helper
lets you easily, correctly, and safely mount, unmount, automount, various devices, filesystems, network shares, gocryptfs vaults, etc, on any system.Related commands:
get-devices
cross-platform fetching and filtering of select and complete device informationgocryptfs-helper
helpers for GoCryptFSwhat-is-using
find out what is using a path so that you can unmount it safely
-
Dorothy also provides commands for writing commands, such as:
bash.bash
for a Bash strict mode that actually works, and various shims/polyfillsask
,confirm
, andchoose
for prompting the user for inputecho-style
,echo-error
,echo-verbose
, andeval-helper
for output styling- Dozens of
echo-*
,fs-*
,get-*
, andis-*
helpers
Beta commands:
mail-sync
helps you migrate all your emails from one cloud provider to another.
Stable commands:
alias-helper
helps you manage your macOS aliases, and if desired, convert them into symlinks.macos-drive
helps you turn a macOS installer into a bootable USB drive.macos-installer
fetches the latest macOS installer.sparse-vault
lets you easily, and for free, create secure encrypted password-protected vaults on your mac, for securing those super secret data.
Beta commands:
eject-all
eject all removable drives safely.icloud-helper
can free up space for time machine by evicting local iCloud caches.itunes-owners
generates a table of who legally owns what inside your iTunes Media Library β which is useful for debugging certain iTunes Store authorization issues, which can occur upon backup restorations.macos-settings
helps configure macOS to your preferred system preferences.macos-state
helps you backup and restore your various application and system preferences, from time machine backups, local directories, and sftp locations. This makes setting up clean installs easy, as even the configuration is automated. And it also helps you never forget an important file, like your env secrets ever again.macos-theme
helps you change your macOS theme to your preference, including your wallpaper and editor.tmutil-helper
can free up space for bootcamp by evicting local Time Machine caches.
Beta commands:
convert-helper
convert one media format to anotherget-codec
gets the codec of a media fileis-audio-mono
checks if an audio file is monois-audio-stereo
checks if an audio file is stereopdf-decrypt
will mass decrypt encrypted PDFs.pdf-decrypt
decrypts a PDF filesvg-export
converts an SVG image into a desired image formatvideo-merge
will merge multiple video files in a directory together into a single video file.wallhaven-helper
download your wallpaper collections from Wallhavenxps2pdf
will convert a legacy XPS document into a modern PDF document.ytd-helper
helps you download videos from the internet with simplified options.
Join the Bevry Software community to stay up-to-date on the latest Dorothy developments and to get in touch with the rest of the community.
Discover how to contribute via the CONTRIBUTING.md
file.
- Benjamin Lupton β Accelerating collaborative wisdom.
- Benjamin Lupton β Accelerating collaborative wisdom.
- Benjamin Lupton β view contributions
- Bevry Team β view contributions
- BJReplay β view contributions
- molleweide β view contributions
- Nutchanon Ninyawee β view contributions
- Sumit Rai β view contributions
- Andrew Nesbitt β Software engineer and researcher
- Codecov β Empower developers with tools to improve code quality and testing.
- Frontend Masters β The training platform for web app engineering skills β from front-end to full-stack! π
- Poonacha Medappa
- Rob Morris
- Sentry β Real-time crash reporting for your web apps, mobile apps, and games.
- Syntax β Syntax Podcast
- Andrew Nesbitt
- Balsa
- Chad
- Codecov
- entroniq
- Frontend Masters
- Jean-Luc Geering
- Michael Duane Mooring
- Mohammed Shah
- Mr. Henry
- Poonacha Medappa
- Rob Morris
- Sentry
- ServieJS
- Syntax
Unless stated otherwise all works are:
- Copyright Β© Benjamin Lupton
and licensed under: