Skip to main content

Library for verifying Yubikey One Time Passwords (OTPs)

Project description

Yubico Python Client

https://img.shields.io/pypi/v/yubico-client.svg https://img.shields.io/pypi/dm/yubico-client.svg https://secure.travis-ci.org/Kami/python-yubico-client.png?branch=master https://img.shields.io/codecov/c/github/Kami/python-yubico-client/master.svg https://img.shields.io/pypi/pyversions/yubico-client.svg https://img.shields.io/pypi/wheel/yubico-client.svg https://img.shields.io/github/license/Kami/python-yubico-client.svg

Python class for verifying Yubico One Time Passwords (OTPs) based on the validation protocol version 2.0.

For more information and usage examples, please see the. documentation.

Documentation

Documentation is available at https://yubico-client.readthedocs.org/en/latest/

Installation

$ pip install yubico-client

Note: Package has been recently renamed from yubico to yubico-client and the main module has been renamed from yubico to yubico_client. This was done to avoid naming conflicts and make creation of distribution specific packages easier.

Supported Python Versions

  • Python 2.7

  • Python 3.4

  • Python 3.5

  • Python 3.6

  • Python 3.7

  • PyPy 2

  • PyPy 3

Running Tests

To run the tests use the tox command. This will automatically run the tests on all the supported Python versions.

$ tox

License

Yubico Client is distributed under the 3-Clause BSD License.

Changelog

1.12.0 - 2019-11-18

  • Update code to retry HTTP requests for server errors which might work on a retry (5xx status codes returned by the server). Those errors could simply indicate a gateway or a proxy error which might work on a retry.

    Contributed by Nigel Williams (@nrw505) #30

  • Pin minimum version for requests dependency to v2.22.0.

  • Update the code so we don’t throw an exception if one of the multiple servers we query has issues.

    We query multiple servers in parallel purely for availability reasons and the consistency / sync part is taken care by the server side. The client returns immediately as soon as it receives one positive or a negative response.

    Contributed by Nigel Williams (@nrw505) #29

  • Update code so we send User-Agent header which includes client version information and platform string with each HTTP request.

  • Also test the code with Python 3.8.0 and indicate we also support Python 3.8.

1.11.0 - 2019-07-06

  • Drop support for Python 2.6. #28

  • Test the code and verify it works with the following Python versions: * Python 3.3 * Python 3.4 * Python 3.5 * Python 3.6 * Python 3.7 * PyPy 2 * PyPy 3 #28

1.10.0 - 2015-10-02

  • Fix compatibility issue with Python versions >= 3.0 <= 3.3 #22

  • Pin requests dependency to the latest version (2.7) #25 #27

    Contribution by Wouter van Bommel, Vianney Carel.

  • Make sure the query parameters are unquoted when parsing them from the response. #23

    Contribution by Tamás Gulácsi.

1.9.1 - 2014-02-05

  • Fix Python 3 compatibility issue. #21

1.9.0 - 2014-01-16

  • To discourage bad practices, remove use_https argument from the Yubico class constructor all together. Also update DEFAULT_API_URLS variable to contain full URLs with a scheme (e.g. https://api.yubico.com/wsapi/2.0/verify).

    If a user wants to use a custom non-https URL or URLs, they can still do that by passing api_urls argument with custom non-https URLs to the constructor.

  • Replace CA_CERTS_BUNDLE_PATH module level variable with a ca_certs_bundle_path argument which can be passed to the Yubico class constructor.

  • Update requests dependency from 1.2 to 2.2.

1.8.0 - 2013-11-09

  • Modify verify_multi method to throw if otp_list argument contains less than two items

  • Modify max_time_window argument in the verify_multi method to be in seconds (#19)

  • Modify verify_multi method to throw if delta between the first and last OTP timestamp is smaller than zero

  • Allow user to pass api_urls argument to the Yubico class constructor. This argument can contain a list of API urls which are used to validate the token. https://github.com/Kami/python-yubico-client/pull/18

    Contributed by Dain Nilsson

  • Depend on newer version (1.2.3) of the requests library.

  • Update code and tests so they also work under Python 3.3

1.7.0 - 2013-04-06

  • Change PyPi package name from yubico to yubico-client.

    This was done to prevent naming collisions and make creation of distribution specific packages (e.g. debian packages) easier.

1.6.2 - 2013-04-02

  • If there are multiple interpretations for a given OTP, first try to find the one which matches the input OTP. If the one is found, use the input OTP, otherwise use random interpretation. - https://github.com/Kami/python-yubico-client/issues/14

    Reported by Klas Lindfors

1.6.1 - 2013-03-19

1.6.0 - 2013-01-24

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

yubico-client-1.12.0.tar.gz (21.5 kB view details)

Uploaded Source

Built Distribution

yubico_client-1.12.0-py2.py3-none-any.whl (17.7 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file yubico-client-1.12.0.tar.gz.

File metadata

  • Download URL: yubico-client-1.12.0.tar.gz
  • Upload date:
  • Size: 21.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.14.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/40.8.0 requests-toolbelt/0.9.1 tqdm/4.35.0 CPython/2.7.17

File hashes

Hashes for yubico-client-1.12.0.tar.gz
Algorithm Hash digest
SHA256 1d74c6341210c94b639f7c7c8930550e73d5c1be60402e418e9dc95e038f8527
MD5 57b4340cbfad82b9adb7cbe85587b468
BLAKE2b-256 6f7cba11726131ce07785a156bc460584be9c78a28a93b9d05e79300364c39a7

See more details on using hashes here.

File details

Details for the file yubico_client-1.12.0-py2.py3-none-any.whl.

File metadata

  • Download URL: yubico_client-1.12.0-py2.py3-none-any.whl
  • Upload date:
  • Size: 17.7 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.14.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/40.8.0 requests-toolbelt/0.9.1 tqdm/4.35.0 CPython/2.7.17

File hashes

Hashes for yubico_client-1.12.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 c90c47ec4596f0508f2d202c9c216ca3854284f8c5833dc814c36089794e0aa2
MD5 2fbf49effbb12bb676c8e1abc96a424a
BLAKE2b-256 f76aec5b0d2e521f501518ee913d327b04f7edda6be6b28fe77441f211007523

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