magical shell history
[English] | [简体中文]
Atuin replaces your existing shell history with a SQLite database, and records additional context for your commands. Additionally, it provides optional and fully encrypted synchronisation of your history between machines, via an Atuin server.
exit code, duration, time and command shown
As well as the search UI, it can do things like this:
```
make
commands, recorded after 3pm yesterdayatuin search --exit 0 --after "yesterday 3pm" make ```
You may use either the server I host, or host your own! Or just don't use sync at all. As all history sync is encrypted, I couldn't access your data even if I wanted to. And I really don't want to.
up
and ctrl-r
with a full screen history search UIAtuin has a community Discord, available here
This will sign you up for the default sync server, hosted by me. Everything is end-to-end encrypted, so your secrets are safe!
Read more below for offline-only usage, or for hosting your own server.
``` bash <(curl https://raw.githubusercontent.com/ellie/atuin/main/install.sh)
atuin register -u
Alongside the hosted Atuin server, there is also a service which generates activity graphs for your shell history! These are inspired by the GitHub graph.
For example, here is mine:
If you wish to get your own, after signing up for the sync server, run this
curl https://api.atuin.sh/enable -d $(cat ~/.local/share/atuin/session)
The response includes the URL to your graph. Feel free to share and/or embed this URL, the token is not a secret, and simply prevents user enumeration.
``` bash <(curl https://raw.githubusercontent.com/ellie/atuin/main/install.sh)
atuin import auto ```
The install script will help you through the setup, ensuring your shell is properly configured. It will also use one of the below methods, preferring the system package manager where possible (pacman, homebrew, etc etc).
```
bash <(curl https://raw.githubusercontent.com/ellie/atuin/main/install.sh) ```
It's best to use rustup to get setup with a Rust toolchain, then you can run:
cargo install atuin
And then follow the shell setup
brew install atuin
And then follow the shell setup
Atuin is also available in MacPorts
sudo port install atuin
And then follow the shell setup
Atuin is available in the Arch Linux community repository:
pacman -S atuin
And then follow the shell setup
git clone https://github.com/ellie/atuin.git
cd atuin
cargo install --path .
And then follow the shell setup
Once the binary is installed, the shell plugin requires installing. If you use the install script, this should all be done for you!
echo 'eval "$(atuin init zsh)"' >> ~/.zshrc
Or using a plugin manager:
zinit load ellie/atuin
We need to setup some hooks, so first install bash-preexec:
curl https://raw.githubusercontent.com/rcaloras/bash-preexec/master/bash-preexec.sh -o ~/.bash-preexec.sh
echo '[[ -f ~/.bash-preexec.sh ]] && source ~/.bash-preexec.sh' >> ~/.bashrc
Then setup Atuin
echo 'eval "$(atuin init bash)"' >> ~/.bashrc
Add
atuin init fish | source
to your is-interactive
block in your ~/.config/fish/config.fish
file
Install atuin
shell plugin in zsh, bash, or fish with Fig in one click.
Atuin is named after "The Great A'Tuin", a giant turtle from Terry Pratchett's Discworld series of books.