Skip to main content

Rofi frontend for Bitwarden

Project description

rbw-rofi

A rofi (and dmenu-like) frontend for Bitwarden

Based on the alternative Bitwarden CLI rbw and inspired by rofi-pass, rbw-rofi is a simplistic password typer/copier using rofi, wofi, fuzzel, and bemenu.

Screenshot of rofi-rbw Screenshot of a rofi-rbw entry menu

Features

  • Autotype password or username (Enter/Alt+3 and Alt+2, respectively)
  • Autotype username and password (with a tab character in between) with Alt+1 (and copy TOTP to clipboard)
  • Configure autotyping either as a keybinding or by having a _autotype field in your credential
  • Copy username, password or TOTP to the clipboard (Alt+u, Alt+p and Alt+t, respectively)
  • Show an autotype menu with all fields

Usage

First, you need to configure rbw. See its documentation for that. Then, you can start rofi-rbw. It is not available as a rofi mode.

Configuration

You can configure rofi-rbw either with cli arguments or with a config file called $XDG_CONFIG_HOME/rofi-rbw.rc. In the file, use the long option names without double dashes. Please check the man page for details.

Options

long option short option possible values description
--action -a type (default), copy, print Choose what rofi-rbw should do.
--target -t username, password, notes, totp (or any custom field) Choose which components of the selected entry are interesting. Can be passed multiple times to type/copy/print several components. Default is username and password.
--prompt -r any string Define the text of the prompt.
--keybindings Define custom keybindings in the format <shortcut>:<action>:<target>, for example Alt+x:copy:username. Multiple keybindings can be concatenated with ,; multiple targets for one shortcut can be concatenated with :. Note that wofi and fuzzel don't support keybindings.
--menu-keybindings Define custom keybindings for the target menu in the format <shortcut>:<action>, similar to --keybindings. Note that wofi and fuzzel don't support keybindings.
--no-cache Disable the automatic frecency cache. It contains sha1-hashes of the selected entries and how often they were used.
--clear-after integer number >= 0 (default is 0) Limit the duration in seconds passwords stay in your clipboard (unless overwritten). When set to 0, passwords will be kept indefinitely.
--typing-start-delay delay in milliseconds Set a delay before the typing starts. 0 by default, but that may result in problems
--typing-key-delay delay in milliseconds Set a delay between key presses when typing. 0 by default, but that may result in problems.
--no-help Don't show the help message about the available shortcuts.
--no-folder Don't show the entry's folder in the list.
--selector-args Define arguments that will be passed through to rofi, wofi, fuzzel or bemenu.
Please note that you need to specify it as --selector-args="<args>" or --selector-args " <args>" because of a bug in argparse
--selector rofi, wofi, fuzzel, bemenu Show the selection dialog with this application. Chosen automatically by default.
--clipboarder xsel, xclip, wl-copy Access the clipboard with this application. Chosen automatically by default.
--typer xdotool, wtype, ydotool, dotool Type the characters using this application. Chosen automatically by default.
--use-notify-send Send desktop notification after copying TOTP.

Autotyping

By default, Alt+1 will type username and password, separated with a tab character. However, you can change this behavior by defining your own keybinding (if your selector supports this). For example, Alt+1:type:username:enter:delay:password:enter will type the username, enter, wait for a second and then type the password and enter again.

This sequence can also be defined as a field _autotype on each credential.

Installation

From distribution repositories

Packaging status

From PyPI

rofi-rbw is on PyPI. You can install it with pip install --user rofi-rbw (or sudo pip install rofi-rbw).

Manually

Download the wheel file from releases and install it with pipx install $filename. Note that it needs configargparse to work.

Dependencies

You also need:

  • Python 3.9 or higher
  • rofi, wofi, fuzzel or bemenu
  • Something to programmatically type characters into other applications. Depending on your display server, it's xdotool, wtype, ydotool or dotool.
  • Something to copy text to the clipboard. Again, depending on the display server, you want xclip, xsel or wl-copy.
  • Optionally libnotify to provide notify-send needed for --use-notify-send

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

rofi_rbw-1.6.1.tar.gz (80.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

rofi_rbw-1.6.1-py3-none-any.whl (27.5 kB view details)

Uploaded Python 3

File details

Details for the file rofi_rbw-1.6.1.tar.gz.

File metadata

  • Download URL: rofi_rbw-1.6.1.tar.gz
  • Upload date:
  • Size: 80.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for rofi_rbw-1.6.1.tar.gz
Algorithm Hash digest
SHA256 45a5da9fec1ecaca4a92c07ff2cf2f9e0ccb5f32d7b7ac823130cfa27f23ba71
MD5 fad54aaf9684689a8f60cfd1d1c2c14f
BLAKE2b-256 1f141b40d5bfd078d0b14045a59cfb30d1a50577b65ddbd2bf790bcd8805b494

See more details on using hashes here.

Provenance

The following attestation bundles were made for rofi_rbw-1.6.1.tar.gz:

Publisher: release.yaml on fdw/rofi-rbw

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file rofi_rbw-1.6.1-py3-none-any.whl.

File metadata

  • Download URL: rofi_rbw-1.6.1-py3-none-any.whl
  • Upload date:
  • Size: 27.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for rofi_rbw-1.6.1-py3-none-any.whl
Algorithm Hash digest
SHA256 c54cc6a750fe0f6fbdbffb889dca9cca0280b59c374b65698d483b0628c2a9fd
MD5 5424b610d786a49b9c5d609ce26d4099
BLAKE2b-256 7fb24aae0a002cd36f4f3d726b08af249cbf36e1171a7880d7607ceadbb879de

See more details on using hashes here.

Provenance

The following attestation bundles were made for rofi_rbw-1.6.1-py3-none-any.whl:

Publisher: release.yaml on fdw/rofi-rbw

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page