Skip to main content

Dmenu/Rofi frontend for Bitwarden CLI tool

Project description

Bitwarden-menu

PyPI - Python Version PyPI GitHub contributors

Dmenu/Rofi frontend for managing Bitwarden vaults. Uses the Bitwarden CLI tool to interact with the Bitwarden database.

This project is not associated with the Bitwarden project nor 8bit Solutions LLC.

Installation

pip install --user bitwarden-menu

Ensure ~/.local/bin is in your $PATH. Run bwm and enter your database path, keyfile path, and password.

NOTE: Initial login to some servers, including vault.bitwarden.com, will require the client_secret from your account settings page. Ensure this is in your clipboard and ready to paste prior to first run. Once logged in for the first time, you will not need this value again.

For full installation documention see the [installation docs][docs/install.md].

Full Documentation

Installation - Configuration - Usage

Requirements

  1. Python 3.10+
  2. Bitwarden CLI. Ensure the bw command is in $PATH
  3. Pynput and Xdg
  4. Dmenu, Rofi, Wofi or Bemenu
  5. xsel or wl-copy
  6. (optional) Pinentry.
  7. (optional) xdotool, ydotool(>= 1.0.0)/wtype (for Wayland).

Features

  • Supports multiple bitwarden.com and self-hosted Vaultwarden accounts. Accounts can be switched on the fly.
  • Auto-type username and/or password on selection. Select to clipboard if desired (clipboard clears after 30 sec on X11 or after 1 paste on Wayland).
  • Supports login with 2FA code from Authenticator(TOTP), Email, or Yubikey.
  • Background process allows selectable time-out for locking the database.
  • Use a custom Keepass 2.x style auto-type sequence.
  • Type, view or edit any field.
  • Open the URL in the default web browser.
  • Non U.S. English keyboard languages and layouts supported via xdotool or ydotool/wtype (for Wayland).
  • Edit notes using terminal or gui editor.
  • Add and Delete entries
  • Rename, move, delete and add folders and collections
  • Move any item to or from an organization, including support for multiple collections.
  • Hide selected folders from the default and 'View/Type Individual entries' views.
  • Configure the characters and groups of characters used during password generation.
  • Optional Pinentry support for secure passphrase entry.
  • Add, edit and type TOTP codes.

License

  • MIT

Usage

bwm [-h] [-v VAULT] [-l LOGIN] [-k] [-a AUTOTYPE] [-C] [-c CONFIGPATH]

  • Run bwm or bind to keystroke combination.
  • Enter account URL on first run.
  • Start typing to match entries.
  • Configure ~/.config/bwm/config.ini as desired.
  • More detailed usage information.
  • Screencast (Using Bemenu on Sway):

Screencast

Tests

Run tests using pytest:

# Using make (creates venv automatically)
make test

# With coverage report
make test-cov

# Or install and run directly
pip install .[test]
pytest

Development

  • To install bitwarden-menu in a venv: make

  • Build man page from Markdown source: make man

  • Using hatch:

    • hatch shell: provies venv with editable installation.
    • hatch build && hatch publish: build and publish to Pypi.
  • Using nix:

    • nix develop: Provides development shell with all dependencies.
    • make test and hatch build/publish work as usual.
  • GitHub Action will upload to TestPyPi on each push to main. To create a GitHub and PyPi release, create a new tag (formatting below) and push tags.

      <tag name on first line>
    
      * Release note 1
      * Release note 2
      * ...
    

Planned features

  • Notifications for syncing status (e.g. when a sync is complete)

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

bitwarden_menu-0.5.2.tar.gz (37.6 kB view details)

Uploaded Source

Built Distribution

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

bitwarden_menu-0.5.2-py2.py3-none-any.whl (264.8 kB view details)

Uploaded Python 2Python 3

File details

Details for the file bitwarden_menu-0.5.2.tar.gz.

File metadata

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

File hashes

Hashes for bitwarden_menu-0.5.2.tar.gz
Algorithm Hash digest
SHA256 722cdc1a2ad5c52fb0b2925f30f25ae3b5eaf62c4b8a97f7d4200f3e15c87aa0
MD5 aadcd75e75aed48101877ef3f1a1183a
BLAKE2b-256 4cece2a2e6d78754f4d1a638745e7dbca9e02a5ac415c24058d347b2f57050c4

See more details on using hashes here.

Provenance

The following attestation bundles were made for bitwarden_menu-0.5.2.tar.gz:

Publisher: main.yml on firecat53/bitwarden-menu

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

File details

Details for the file bitwarden_menu-0.5.2-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for bitwarden_menu-0.5.2-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 95440ba157053ea112050029cae35bac83eee06013132dd8f43b032f96e5084e
MD5 2da402385cdd6d14a2311c5dff06cef7
BLAKE2b-256 6e131ad6ad1199050e50ddd4d533c751b12324c221311ff8a7dad5bf9cfbc1fb

See more details on using hashes here.

Provenance

The following attestation bundles were made for bitwarden_menu-0.5.2-py2.py3-none-any.whl:

Publisher: main.yml on firecat53/bitwarden-menu

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