Skip to main content

A CFFI-based implementation of SipHash24

Project description

SipHash is a hash function and message authentication code that is secure, fast and simple. It accepts a 128-bit secret key and a variable-length message, and returns a 64-bit hash. It performs better than most cryptographic hash function-based MACs (especially for short inputs), and offers much better security than non-cryptographic hash functions, providing resistance against hash-flooding DoS attacks. As a result, it is now used as the hash function of choice for hash tables in Python, Ruby, Rust and Redis.

This Python package is the SipHash-2-4 C reference implementation, wrapped with CFFI. It’s incredibly fast: amortized hashing times tested as follows on a mid-2015 MacBook Pro:

Message Size

Time per Hash (Amortized over 1M)

43 bytes

4.89 microseconds

256 bytes

5.00 microseconds

1500 bytes

6.12 microseconds

1 MiB

0.88 milliseconds

Installation

You can get this library with pip:

pip install csiphash

Usage

Currently there’s just a single function, siphash24(), that accepts a secret key bytestring of length 16 and an arbitrary length bytestring for the message, and returns an 8-byte digest bytestring:

>>> from csiphash import siphash24
>>> siphash24(b'\x00' * 16, b'hello, world!\n')
b'\xf1G4\x95\xa5\xaa\xc2b'

If you want to specify keys in hexadecimal, use .decode('hex'):

>>> siphash24('abcdef01234567899876543210fedcba'.decode('hex'), b'hello, world!\n')
'\xd3\xd4N\x1dk\x1f$='

If you want digests in hexadecimal, use .encode('hex'):

>>> siphash24(b'\x00' * 16, b'hello, world!\n').encode('hex')
'f1473495a5aac262'

License

The reference C implementation of SipHash is bundled with this library. It was written by Jean-Philippe Aumasson and Daniel J. Bernstein, and is released under the CC0.

Six is bundled with this library. It was written by Benjamin Peterson, and is licensed under the MIT License.

All other software in this library is released under the UNLICENSE:

This is free and unencumbered software released into the public domain.

Anyone is free to copy, modify, publish, use, compile, sell, or distribute this software, either in source code form or as a compiled binary, for any purpose, commercial or non-commercial, and by any means.

In jurisdictions that recognize copyright laws, the author or authors of this software dedicate any and all copyright interest in the software to the public domain. We make this dedication for the benefit of the public at large and to the detriment of our heirs and successors. We intend this dedication to be an overt act of relinquishment in perpetuity of all present and future rights to this software under copyright law.

THE SOFTWARE IS PROVIDED “AS IS”, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.

For more information, please refer to http://unlicense.org/

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

csiphash-0.0.5.tar.gz (12.9 kB view details)

Uploaded Source

Built Distributions

csiphash-0.0.5-cp36-cp36m-macosx_10_12_x86_64.whl (16.8 kB view details)

Uploaded CPython 3.6m macOS 10.12+ x86-64

csiphash-0.0.5-cp27-cp27m-macosx_10_12_x86_64.whl (16.7 kB view details)

Uploaded CPython 2.7m macOS 10.12+ x86-64

File details

Details for the file csiphash-0.0.5.tar.gz.

File metadata

  • Download URL: csiphash-0.0.5.tar.gz
  • Upload date:
  • Size: 12.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for csiphash-0.0.5.tar.gz
Algorithm Hash digest
SHA256 17eade97b880b40f1f090ff00e3fb60381cdc7d5aac53f4ce89c4ddb466a9900
MD5 2ebb8f238456a87c810dd6dd4a9f6a4d
BLAKE2b-256 c534906ea34f74f5dd53a066f16cf5fe9cdf02bd2fd1be3451a2ddc26c9dec68

See more details on using hashes here.

File details

Details for the file csiphash-0.0.5-cp36-cp36m-macosx_10_12_x86_64.whl.

File metadata

File hashes

Hashes for csiphash-0.0.5-cp36-cp36m-macosx_10_12_x86_64.whl
Algorithm Hash digest
SHA256 ff6d150adeb519467aabc4a84ce5e7470b7ca947b892cb8d17c3720fb9e80640
MD5 e141ecf3f51f72faf53be20af6998f88
BLAKE2b-256 5e3f2b45249a98aaf56515f8aec62f0b77da471a8e507e6982e61fe27f068e45

See more details on using hashes here.

File details

Details for the file csiphash-0.0.5-cp27-cp27m-macosx_10_12_x86_64.whl.

File metadata

File hashes

Hashes for csiphash-0.0.5-cp27-cp27m-macosx_10_12_x86_64.whl
Algorithm Hash digest
SHA256 fb44ea5aa5a36b4b45f4af9efb48fe256c96438eaaf180869c3462f5b76be6a6
MD5 d563d27bec493b3566d29bbdc4743415
BLAKE2b-256 a0e319bd06d65ce8e932a61332b4b00aa986974581dfdbe075eb799b656610d6

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