Skip to content
forked from atuinsh/atuin

✨ Magical shell history

License

Notifications You must be signed in to change notification settings

ltrzesniewski/atuin

This branch is 62 commits behind atuinsh/atuin:main.

Folders and files

NameName
Last commit message
Last commit date
Jun 13, 2024
Dec 5, 2024
Jan 7, 2025
Apr 22, 2024
Jan 8, 2024
Jun 3, 2024
Jul 30, 2024
Apr 14, 2021
Jul 17, 2024
Jul 16, 2024
Apr 28, 2022
Dec 27, 2024
Mar 17, 2022
Jun 12, 2024
Dec 27, 2024
Jan 7, 2025
Dec 27, 2024
Jan 1, 2025
Feb 14, 2021
Jun 26, 2024
Jun 12, 2024
May 14, 2021
Jun 25, 2024
Mar 1, 2023
May 10, 2021
Sep 11, 2023
Dec 5, 2024
Mar 8, 2024
Dec 27, 2024
Oct 22, 2024
Jun 26, 2024
Oct 22, 2024

Repository files navigation

Text changing depending on mode. Light: 'So light!' Dark: 'So dark!'

magical shell history


Arm CI sponsored by Actuated

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.

animated

exit code, duration, time and command shown

As well as the search UI, it can do things like this:

# search for all successful `make` commands, recorded after 3pm yesterday
atuin 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.

Features

  • rebind ctrl-r and up (configurable) to a full screen history search UI
  • store shell history in a sqlite database
  • back up and sync encrypted shell history
  • the same history across terminals, across sessions, and across machines
  • log exit code, cwd, hostname, session, command duration, etc
  • calculate statistics such as "most used command"
  • old history file is not replaced
  • quick-jump to previous items with Alt-<num>
  • switch filter modes via ctrl-r; search history just from the current session, directory, or globally
  • enter to execute a command, tab to edit

Documentation

Supported Shells

  • zsh
  • bash
  • fish
  • nushell
  • xonsh

Community

Forum

Atuin has a community forum, please ask here for help and support: https://forum.atuin.sh/

Discord

Atuin also has a community Discord, available here

Quickstart

This will sign you up for the Atuin Cloud sync server. Everything is end-to-end encrypted, so your secrets are safe!

Read more in the docs for an offline setup, self hosted server, and more.

curl --proto '=https' --tlsv1.2 -LsSf https://setup.atuin.sh | sh

atuin register -u <USERNAME> -e <EMAIL>
atuin import auto
atuin sync

Then restart your shell!

Note

For Bash users: The above sets up bash-preexec for necessary hooks, but bash-preexec has limitations. For details, please see the Bash section of the shell plugin documentation.

Security

If you find any security issues, we'd appreciate it if you could alert ellie@atuin.sh

Contributors

Made with contrib.rocks.

About

✨ Magical shell history

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Rust 95.0%
  • Shell 3.2%
  • Nix 0.5%
  • PLpgSQL 0.5%
  • Xonsh 0.4%
  • Nushell 0.3%
  • Other 0.1%