Skip to main content

Simple password manager. Stores secrets in encrypted tab-delimited table.

Project description

Introduction

Keybox is a secure store for passwords, keys, and other secrets.

There is a Python API (import keybox), a runnable package (python3 -m keybox) and a wrapper script (keybox, created by setuptools).

Keybox is completely offline. All secrets stay safely in a local file. Nothing is sent anywhere, unless you explicitly set up network synchronization using some other tool.

Features:

  • Data encrypted using strong encryption (PyNaCl)

  • Inside encrypted envelope, it’s a simple tab-delimited file format

  • Shell-like text user interface

Security:

  • Master password is saved in memory for as long as the program runs.

  • Neither the password nor decrypted data are written to the disk (unless explicitly exported).

Portability:

  • The script should run on any system with Python3 installed (including Windows).

  • Requires no installation. You can bring your keybox with you anywhere.

  • Can be contained in a single Python file (see Static Distribution below)

Dependencies:

  • Python 3.7 or later

  • PyNaCl, prompt_toolkit, blessed, pyperclip

Installation

Install Python package, together with the keybox wrapper script, from PyPI:

pip3 install keybox

That’s it. PIP should pull in the required dependencies.

From source / Git repo

Alternatively, install from source:

python3 setup.py install

The package can also run without installation, directly from source tree root:

python3 -m keybox

Dependencies

  • pynacl - the encryption

  • argon2-cffi - optional, replaces argon2 from PyNaCl when available

  • prompt_toolkit, blessed, pyperclip - command-line and shell

  • /usr/share/dict/words

    • used for password generator

    • Debian: apt install wamerican

    • when not available, a replacement words file is downloaded from Internet (This is the only option on Windows)

  • pytest, coverage - for tests

Getting Started

Run the program, choose a master password. A new keybox file will be created.

You are now in the shell. The basic workflow uses the following commands:

  • add some passwords

  • list the records

  • select a record

  • print the password

  • quit

Type help for a list of all commands, help <cmd> for description of each command and its parameters.

Config file

The default config file path is ~/.keybox/keybox.conf. It can be used to point to a different location for the keybox file:

[keybox]
path = ~/vcs/keybox/keybox.safe

Without the config file, the default keybox path is ~/.keybox/keybox.safe.

Password Generator

A bundled password generator can be called from command line (keybox pwgen) or internally from the shell. In the shell, use <tab> when asked for a password (in the add/modify commands) to generate some random passwords.

Pwgen is based on the system word list that is usually found in /usr/share/dict/words. By default, it generates a password from two concatenated words, altered by adding two uppercase letters and one digit somewhere inside the password.

This gives around 50 bits of entropy on my system (Password strength).

Static Distribution

Call make zipapp to create a zipapp file containing all sources. The zipapp file is written to build directory and is directly executable by Python.

The Makefile target uses zipapp module which is available since Python 3.5.

Development

Build docs:

make -C docs html

Run tests:

make test

Show test code coverage:

make htmlcov

Build and check package:

make build
make check

The Project Name

There might be some confusion between this Keybox project and GnuPG project, which has something called “a keybox file (.kbx)” and a tool to handle it, kbxutil.

This Keybox is completely unrelated to the GnuPG one.

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

keybox-0.5.0.tar.gz (57.7 kB view details)

Uploaded Source

Built Distribution

keybox-0.5.0-cp310-cp310-macosx_11_0_x86_64.whl (50.5 kB view details)

Uploaded CPython 3.10 macOS 11.0+ x86-64

File details

Details for the file keybox-0.5.0.tar.gz.

File metadata

  • Download URL: keybox-0.5.0.tar.gz
  • Upload date:
  • Size: 57.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.2 importlib_metadata/4.8.1 pkginfo/1.7.1 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.60.0 CPython/3.9.8

File hashes

Hashes for keybox-0.5.0.tar.gz
Algorithm Hash digest
SHA256 bd85966971274437ee73b6a6cf50df06314d03fb430aff5e2e2b603b0304e09b
MD5 d07c843b7174229d3c30050d60de9840
BLAKE2b-256 2d78851cd2cb49330b0fc817fc992261e391464e6d08d38f28261ce9175ac6fe

See more details on using hashes here.

File details

Details for the file keybox-0.5.0-cp310-cp310-macosx_11_0_x86_64.whl.

File metadata

  • Download URL: keybox-0.5.0-cp310-cp310-macosx_11_0_x86_64.whl
  • Upload date:
  • Size: 50.5 kB
  • Tags: CPython 3.10, macOS 11.0+ x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.2 importlib_metadata/4.8.1 pkginfo/1.7.1 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.60.0 CPython/3.9.8

File hashes

Hashes for keybox-0.5.0-cp310-cp310-macosx_11_0_x86_64.whl
Algorithm Hash digest
SHA256 f70f897b62cfb2b188d19eaf51237dad269042d09d89ed7acec92cd262e880b7
MD5 2d04cf8e65af7dd4796e0edd172f1b24
BLAKE2b-256 b9123ce1d7552ce4bf12c0a465962385ccb459a7a8d570c04640e86e37d4cd1e

See more details on using hashes here.

Supported by

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