Skip to main content

OTP command line tool

Project description

Travis state

Keyring OTP

Keyring OTP is a CLI to generate One Time Password from secrets stored in Gnome Keyring (the seahorse’s backend).

Installation

This application is properly running on debian stretch in python3 virtual environement:

$ python3 -m venv koptvenv
$ source ./kotpvenv/bin/activate

This requiere xclip on your computer to temporary put the secret in your clipboard at the end of the program the initial value is back in your clipboard:

$ apt install xclip

Install using your favorite installer. For example:

$ pip install keyring-otp

Usage

use -h to get recent help:

$ kotp -h
usage: kotp [-h] [-s SECRET] [-o] [-d DURATION] keyring key

CLI to generate One Time Password from secrets stored in Keyring (using
seahorse password manager)

positional arguments:
  keyring
  key

optional arguments:
  -h, --help            show this help message and exit
  -s SECRET, --secret SECRET
                        Force using secret from command line instead getting
                        it from the password manager. (as keyring and key are
                        mandatory set any values they will be ignored).
  -o, --output          Display output in console and in the clipboard (useful
                        if you can't install xclip).
  -d DURATION, --duration DURATION
                        How many seconds you wants the One Time Password in
                        your clipboard. Note that as time is changing, the
                        TOTP password will be updated and your clipboard will
                        be updated too!

Let’s assume I’ve a keyring called otp which contains a key called github wich contains my github otp password.

Seahorse Gnome password manager

To get the Time based OTP password in my clipboad I do:

$ kotp otp github

Here an other example by giving the OTP password value in command line:

$ kotp -s SECRETS -o -d 35 nothing real
Current TOTP 887562 at Wed Nov  8 07:48:18 2017
Current TOTP 291833 at Wed Nov  8 07:48:30 2017

Roadmap

  • make it usable as an API, API consumer may add multiple callback they should be called once OTP as benn changed (callback may be declared in entry point to let user define new callback easly), this apps should declare some default behaviours likes:

    • print in console

    • filling clipboard (require an init method and final method to set back current clipboad value)

  • Prompt to unlock keyring

  • Thinking replace -s option and open secret input to avoid le trace in use bash history

  • use python keyring to make this app portable with more password manager: GnomeKeyring (for Gnome environments) or KDEWallet (for KDE environments) or Win32CryptoRegistry (for Windows)

  • manage passman backends

  • save new secrets

Author

Changelog

0.3 (unreleased)
0.2 (2117-11-19)
  • setup travis

  • set clipboad only when TOTP has been changed

  • fix readme.rst to make cleaner on pypi

0.1 (2017-11-11)
  • Initial implementation

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

keyring-otp-0.2.tar.gz (40.4 kB view details)

Uploaded Source

Built Distribution

keyring_otp-0.2-py3-none-any.whl (8.1 kB view details)

Uploaded Python 3

File details

Details for the file keyring-otp-0.2.tar.gz.

File metadata

  • Download URL: keyring-otp-0.2.tar.gz
  • Upload date:
  • Size: 40.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for keyring-otp-0.2.tar.gz
Algorithm Hash digest
SHA256 59905e4dc97e01a7996040416e7282d1bab7f5b1df405ee5cbc93d55fb8e8c64
MD5 04794f3b0f810ff789fd2f12faaf4f46
BLAKE2b-256 0317703b1727bd2d81c9e521ecbe5f90f8852cd506faad0302fa49fa349a36db

See more details on using hashes here.

File details

Details for the file keyring_otp-0.2-py3-none-any.whl.

File metadata

File hashes

Hashes for keyring_otp-0.2-py3-none-any.whl
Algorithm Hash digest
SHA256 2215e1f6916b54abbe8baa460bbd13581e8bc132645859313151d75d12bb4a00
MD5 17285cac075ccd7b5c153da93088116b
BLAKE2b-256 53dae79e1d2124a2bac0cf87579e92a2d98837764f215278d8b1557f2944379f

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