Skip to main content

Split secrets into T pieces, or recover split secrets by recombining any D pieces.

Project description

Split secrets into T pieces. The secret can be recovered by recombining any D pieces.

Overview (wikipedia)

This module implements:

Splitting is done by:

  1. Apply a random mask to the secret
  2. For each block of the mask, generate a polynomial of degree D-1
  3. A piece consists of the masked secret and one point of each polynomial

Recovering is done by:

  1. Collect D pieces: D polynomials for each block of the mask
  2. Interpolate the points to retrieve the blocks of the mask
  3. Recover the secret by re-applying the mask to the masked version

A puzzle piece is a yaml serialisation of the following mapping:

# string, tells if the secret encoded is a string encoded as UTF-8 ("utf-8") or a raw stream of bytes ("none")
encoding: utf-8

# one  puzzle piece, exact format depending on the implementation
# this implementation stores a sequence of [point, value] items, one per block of the secret
# Flow-sequence format preferred to keep it on one line
puzzle piece: [[1,258],[1,3]]

# base64 representation of the result of the mask XOR the byte representation of the secret
encoded secret: YXo=

# name of the algorithm used for splitting
algorithm: block-wise SSS

# different algorithms might add additional information required for recovering the secret.

Working on blocks makes the algorithm linear in the number of bytes of the secret rather than exponential.

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

secret_splitter-1.0.0.tar.gz (18.8 kB view details)

Uploaded Source

Built Distribution

secret_splitter-1.0.0-py3-none-any.whl (11.2 kB view details)

Uploaded Python 3

File details

Details for the file secret_splitter-1.0.0.tar.gz.

File metadata

  • Download URL: secret_splitter-1.0.0.tar.gz
  • Upload date:
  • Size: 18.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.8.10

File hashes

Hashes for secret_splitter-1.0.0.tar.gz
Algorithm Hash digest
SHA256 3c92dfbcfe5b63d8bc6d964ea19609e643c5c2220ac8de0e91537441e557a854
MD5 d37ec3c6b33a243e2c982a9d8859da0f
BLAKE2b-256 1f66906633f49834479a587acf590b26ab1254712278eafa0834b66d5cf286a9

See more details on using hashes here.

File details

Details for the file secret_splitter-1.0.0-py3-none-any.whl.

File metadata

File hashes

Hashes for secret_splitter-1.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 3cca26067e831cc52fbd3a3e185d1705a762b906dab62f0df65e7a9e1837122a
MD5 0413e5b59ed7b2a53085bebfbb84b509
BLAKE2b-256 81fb0baca3a0209770ec6deb6043427b82cb2a80eac0bdbe76b84565ee1da6c3

See more details on using hashes here.

Supported by

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