Name | fastecdsa JSON |
Version |
3.0.0
JSON |
| download |
home_page | None |
Summary | Fast elliptic curve digital signatures |
upload_time | 2025-01-01 16:38:59 |
maintainer | None |
docs_url | None |
author | None |
requires_python | >=3.9 |
license | 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/> |
keywords |
elliptic
curve
cryptography
ecdsa
ecc
|
VCS |
|
bugtrack_url |
|
requirements |
No requirements were recorded.
|
Travis-CI |
No Travis.
|
coveralls test coverage |
No coveralls.
|
fastecdsa
=========
.. image:: https://img.shields.io/pypi/v/fastecdsa.svg
:target: https://pypi.org/project/fastecdsa/
:alt: PyPI
.. image:: https://readthedocs.org/projects/fastecdsa/badge/?version=stable
:target: https://fastecdsa.readthedocs.io/en/stable/?badge=stable
:alt: Documentation Status
.. contents::
About
-----
This is a python package for doing fast elliptic curve cryptography, specifically
digital signatures.
Security
--------
There is no nonce reuse, no branching on secret material,
and all points are validated before any operations are performed on them. Timing side challenges
are mitigated via Montgomery point multiplication. Nonces are generated per RFC6979_. The default
curve used throughout the package is P256 which provides 128 bits of security. If you require a
higher level of security you can specify the curve parameter in a method to use a curve over a
bigger field e.g. P384. All that being said, crypto is tricky and I'm not beyond making mistakes.
Please use a more established and reviewed library for security critical applications. Open an
issue or email me if you see any security issue or risk with this library.
Python Versions Supported
-------------------------
The initial release of this package was targeted at python2.7. Earlier versions may work but have
no guarantee of correctness or stability. As of release 1.2.1+ python3 is supported as well. Due to
python2's EOL on January 1st 2020 release 2.x of this package only supports python3.5+.
Operating Systems Supported
---------------------------
This package is targeted at the Linux and MacOS operating systems. Due to the the dependency on
the GMP C library building this package on Windows is difficult and no official support or
distributions are provided for Windows OSes. See issue11_ for what users have done to get things
building.
Supported Primitives
--------------------
Curves over Prime Fields
~~~~~~~~~~~~~~~~~~~~~~~~
+---------------------------+-----------------------------------------+-------------+
| Name | Class | Proposed By |
+===========================+=========================================+=============+
| P192 / secp192r1 | :code:`fastecdsa.curve.P192` | NIST / NSA |
+---------------------------+-----------------------------------------+-------------+
| P224 / secp224r1 | :code:`fastecdsa.curve.P224` | NIST / NSA |
+---------------------------+-----------------------------------------+-------------+
| P256 / secp256r1 | :code:`fastecdsa.curve.P256` | NIST / NSA |
+---------------------------+-----------------------------------------+-------------+
| P384 / secp384r1 | :code:`fastecdsa.curve.P384` | NIST / NSA |
+---------------------------+-----------------------------------------+-------------+
| P521 / secp521r1 | :code:`fastecdsa.curve.P521` | NIST / NSA |
+---------------------------+-----------------------------------------+-------------+
| secp192k1 | :code:`fastecdsa.curve.secp192k1` | Certicom |
+---------------------------+-----------------------------------------+-------------+
| secp224k1 | :code:`fastecdsa.curve.secp224k1` | Certicom |
+---------------------------+-----------------------------------------+-------------+
| secp256k1 (bitcoin curve) | :code:`fastecdsa.curve.secp256k1` | Certicom |
+---------------------------+-----------------------------------------+-------------+
| brainpoolP160r1 | :code:`fastecdsa.curve.brainpoolP160r1` | BSI |
+---------------------------+-----------------------------------------+-------------+
| brainpoolP192r1 | :code:`fastecdsa.curve.brainpoolP192r1` | BSI |
+---------------------------+-----------------------------------------+-------------+
| brainpoolP224r1 | :code:`fastecdsa.curve.brainpoolP224r1` | BSI |
+---------------------------+-----------------------------------------+-------------+
| brainpoolP256r1 | :code:`fastecdsa.curve.brainpoolP256r1` | BSI |
+---------------------------+-----------------------------------------+-------------+
| brainpoolP320r1 | :code:`fastecdsa.curve.brainpoolP320r1` | BSI |
+---------------------------+-----------------------------------------+-------------+
| brainpoolP384r1 | :code:`fastecdsa.curve.brainpoolP384r1` | BSI |
+---------------------------+-----------------------------------------+-------------+
| brainpoolP512r1 | :code:`fastecdsa.curve.brainpoolP512r1` | BSI |
+---------------------------+-----------------------------------------+-------------+
Arbitrary Curves
~~~~~~~~~~~~~~~~
As of version 1.5.1 construction of arbitrary curves in Weierstrass form
(:code:`y^2 = x^3 + ax + b (mod p)`) is supported. I advise against using custom curves for any
security critical applications. It's up to you to make sure that the parameters you pass here are
correct, no validation of the base point is done, and in general no sanity checks are done. Use
at your own risk.
.. code:: python
from fastecdsa.curve import Curve
curve = Curve(
name, # (str): The name of the curve
p, # (long): The value of p in the curve equation.
a, # (long): The value of a in the curve equation.
b, # (long): The value of b in the curve equation.
q, # (long): The order of the base point of the curve.
gx, # (long): The x coordinate of the base point of the curve.
gy, # (long): The y coordinate of the base point of the curve.
oid # (str): The object identifier of the curve (optional).
)
Hash Functions
~~~~~~~~~~~~~~
Any hash function in the :code:`hashlib` module (:code:`md5, sha1, sha224, sha256, sha384, sha512`)
will work, as will any hash function that implements the same interface / core functionality as the
those in :code:`hashlib`. For instance, if you wish to use SHA3 as the hash function the
:code:`pysha3` package will work with this library as long as it is at version >=1.0b1 (as previous
versions didn't work with the :code:`hmac` module which is used in nonce generation). Note
that :code:`sha3_224, sha3_256, sha3_384, sha3_512` are all in :code:`hashlib` as of python3.6.
Performance
-----------
Curves over Prime Fields
~~~~~~~~~~~~~~~~~~~~~~~~
Currently it does elliptic curve arithmetic significantly faster than the :code:`ecdsa`
package. You can see the times for 1,000 signature and verification operations over
various curves below. These were run on an early 2014 MacBook Air with a 1.4 GHz Intel
Core i5.
+-----------+------------------------+--------------------+---------+
| Curve | :code:`fastecdsa` time | :code:`ecdsa` time | Speedup |
+-----------+------------------------+--------------------+---------+
| P192 | 3.62s | 1m35.49s | ~26x |
+-----------+------------------------+--------------------+---------+
| P224 | 4.50s | 2m13.42s | ~29x |
+-----------+------------------------+--------------------+---------+
| P256 | 6.15s | 2m52.43s | ~28x |
+-----------+------------------------+--------------------+---------+
| P384 | 12.11s | 6m21.01s | ~31x |
+-----------+------------------------+--------------------+---------+
| P521 | 22.21s | 11m39.53s | ~31x |
+-----------+------------------------+--------------------+---------+
| secp256k1 | 5.92s | 2m57.19s | ~30x |
+-----------+------------------------+--------------------+---------+
Installing
----------
You can use pip: :code:`$ pip install fastecdsa` or clone the repo and use
:code:`$ python setup.py install`. Note that you need to have a C compiler.
You also need to have GMP_ on your system as the underlying
C code in this package includes the :code:`gmp.h` header (and links against gmp
via the :code:`-lgmp` flag). You can install all dependencies as follows:
apt
~~~
.. code:: bash
$ sudo apt-get install python3-dev libgmp3-dev
brew
~~~~
.. code:: bash
$ brew install gmp
yum
~~~
.. code:: bash
$ sudo yum install python-devel gmp-devel
Development
-----------
This package uses :code:`uv` for package management. You can install it via `pip install uv`. First build
the C extension modules
.. code:: bash
$ uv run python setup.py build_ext --inplace
To run the test suite use the following command
.. code:: bash
$ uv run pytest
Install pre-commit hooks to ensure type checking and autoformatting happens before you commit your code
.. code:: bash
$ uv run pre-commit install
To build the docs use the following command, which will create a :code:`docs/_build` directory with the
docs built as HTML files
.. code:: bash
$ cd docs
$ uv run make html
Publishing
~~~~~~~~~~
Note that currently only the package owner is able to publish releases to PyPI. The following steps
can still be used to generate source and wheel distributions, but note that the publish command will
not work.
To build a release first install all supported versions of python into the environment (double check
:code:`pyproject.toml` for which python versions are supported)
.. code:: bash
$ uv python install 3.9 3.10 3.11 3.12 3.13
Then build a source distribution, followed by wheels for each supported python version
.. code:: bash
$ uv build --sdist
$ uv build --wheel -p 3.x # do this for each supported python version
Then publish the source and wheels distributions to the test PyPI account.
.. code:: bash
$ uv publish --token {token} --url https://test.pypi.org/simple/
Benchmarking
------------
If you'd like to benchmark performance on your machine you can do so using the command:
.. code:: bash
$ uv run benchmark
This will use the :code:`timeit` module to benchmark 1000 signature and verification operations
for each curve supported by this package. Alternatively, if you have not cloned the repo but
have installed the package via e.g. :code:`pip` you can use the following command:
.. code:: bash
$ python -m fastecdsa.benchmark
Usage
-----
Generating Keys
~~~~~~~~~~~~~~~
You can use this package to generate keys if you like. Recall that private keys on elliptic curves
are integers, and public keys are points i.e. integer pairs.
.. code:: python
from fastecdsa import keys, curve
"""The reason there are two ways to generate a keypair is that generating the public key requires
a point multiplication, which can be expensive. That means sometimes you may want to delay
generating the public key until it is actually needed."""
# generate a keypair (i.e. both keys) for curve P256
priv_key, pub_key = keys.gen_keypair(curve.P256)
# generate a private key for curve P256
priv_key = keys.gen_private_key(curve.P256)
# get the public key corresponding to the private key we just generated
pub_key = keys.get_public_key(priv_key, curve.P256)
Signing and Verifying
~~~~~~~~~~~~~~~~~~~~~
Some basic usage is shown below:
.. code:: python
from fastecdsa import curve, ecdsa, keys
from hashlib import sha384
m = "a message to sign via ECDSA" # some message
''' use default curve and hash function (P256 and SHA2) '''
private_key = keys.gen_private_key(curve.P256)
public_key = keys.get_public_key(private_key, curve.P256)
# standard signature, returns two integers
r, s = ecdsa.sign(m, private_key)
# should return True as the signature we just generated is valid.
valid = ecdsa.verify((r, s), m, public_key)
''' specify a different hash function to use with ECDSA '''
r, s = ecdsa.sign(m, private_key, hashfunc=sha384)
valid = ecdsa.verify((r, s), m, public_key, hashfunc=sha384)
''' specify a different curve to use with ECDSA '''
private_key = keys.gen_private_key(curve.P224)
public_key = keys.get_public_key(private_key, curve.P224)
r, s = ecdsa.sign(m, private_key, curve=curve.P224)
valid = ecdsa.verify((r, s), m, public_key, curve=curve.P224)
''' using SHA3 via pysha3>=1.0b1 package '''
import sha3 # pip install [--user] pysha3==1.0b1
from hashlib import sha3_256
private_key, public_key = keys.gen_keypair(curve.P256)
r, s = ecdsa.sign(m, private_key, hashfunc=sha3_256)
valid = ecdsa.verify((r, s), m, public_key, hashfunc=sha3_256)
Arbitrary Elliptic Curve Arithmetic
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
The :code:`Point` class allows arbitrary arithmetic to be performed over curves. The two main
operations are point addition and point multiplication (by a scalar) which can be done via the
standard python operators (:code:`+` and :code:`*` respectively):
.. code:: python
# example taken from the document below (section 4.3.2):
# https://koclab.cs.ucsb.edu/teaching/cren/docs/w02/nist-routines.pdf
from fastecdsa.curve import P256
from fastecdsa.point import Point
xs = 0xde2444bebc8d36e682edd27e0f271508617519b3221a8fa0b77cab3989da97c9
ys = 0xc093ae7ff36e5380fc01a5aad1e66659702de80f53cec576b6350b243042a256
S = Point(xs, ys, curve=P256)
xt = 0x55a8b00f8da1d44e62f6b3b25316212e39540dc861c89575bb8cf92e35e0986b
yt = 0x5421c3209c2d6c704835d82ac4c3dd90f61a8a52598b9e7ab656e9d8c8b24316
T = Point(xt, yt, curve=P256)
# Point Addition
R = S + T
# Point Subtraction: (xs, ys) - (xt, yt) = (xs, ys) + (xt, -yt)
R = S - T
# Point Doubling
R = S + S # produces the same value as the operation below
R = 2 * S # S * 2 works fine too i.e. order doesn't matter
d = 0xc51e4753afdec1e6b6c6a5b992f43f8dd0c7a8933072708b6522468b2ffb06fd
# Scalar Multiplication
R = d * S # S * d works fine too i.e. order doesn't matter
e = 0xd37f628ece72a462f0145cbefe3f0b355ee8332d37acdd83a358016aea029db7
# Joint Scalar Multiplication
R = d * S + e * T
Importing and Exporting Keys
~~~~~~~~~~~~~~~~~~~~~~~~~~~~
You can also export keys as files, ASN.1 encoded and formatted per RFC5480_ and RFC5915_. Both
private keys and public keys can be exported as follows:
.. code:: python
from fastecdsa.curve import P256
from fastecdsa.keys import export_key, gen_keypair
d, Q = gen_keypair(P256)
# save the private key to disk
export_key(d, curve=P256, filepath='/path/to/exported/p256.key')
# save the public key to disk
export_key(Q, curve=P256, filepath='/path/to/exported/p256.pub')
Keys stored in this format can also be imported. The import function will figure out if the key
is a public or private key and parse it accordingly:
.. code:: python
from fastecdsa.keys import import_key
# if the file is a private key then parsed_d is a long and parsed_Q is a Point object
# if the file is a public key then parsed_d will be None
parsed_d, parsed_Q = import_key('/path/to/file.key')
Other encoding formats can also be specified, such as SEC1_ for public keys. This is done using
classes found in the :code:`fastecdsa.encoding` package, and passing them as keyword args to
the key functions:
.. code:: python
from fastecdsa.curve import P256
from fastecdsa.encoding.sec1 import SEC1Encoder
from fastecdsa.keys import export_key, gen_keypair, import_key
_, Q = gen_keypair(P256)
export_key(Q, curve=P256, filepath='/path/to/p256.key', encoder=SEC1Encoder)
parsed_Q = import_key('/path/to/p256.key', curve=P256, public=True, decoder=SEC1Encoder)
Encoding Signatures
~~~~~~~~~~~~~~~~~~~
DER encoding of ECDSA signatures as defined in RFC2459_ is also supported. The
:code:`fastecdsa.encoding.der` provides the :code:`DEREncoder` class which encodes signatures:
.. code:: python
from fastecdsa.encoding.der import DEREncoder
r, s = 0xdeadc0de, 0xbadc0de
encoded = DEREncoder.encode_signature(r, s)
decoded_r, decoded_s = DEREncoder.decode_signature(encoded)
Acknowledgements
----------------
Thanks to those below for contributing improvements:
- boneyard93501
- clouds56
- m-kus
- sirk390
- targon
- NotStatilko
- bbbrumley
- luinxz
- JJChiDguez
- J08nY
- trevor-crypto
- sylvainpelissier
- akaIDIOT
.. _issue11: https://github.com/AntonKueltz/fastecdsa/issues/11
.. _GMP: https://gmplib.org/
.. _RFC2459: https://tools.ietf.org/html/rfc2459
.. _RFC5480: https://tools.ietf.org/html/rfc5480
.. _RFC5915: https://tools.ietf.org/html/rfc5915
.. _RFC6979: https://tools.ietf.org/html/rfc6979
.. _SEC1: http://www.secg.org/sec1-v2.pdf
Raw data
{
"_id": null,
"home_page": null,
"name": "fastecdsa",
"maintainer": null,
"docs_url": null,
"requires_python": ">=3.9",
"maintainer_email": null,
"keywords": "elliptic, curve, cryptography, ecdsa, ecc",
"author": null,
"author_email": "Anton Kueltz <kueltz.anton@gmail.com>",
"download_url": "https://files.pythonhosted.org/packages/dc/4c/343b2fba2e66d1b476a2f5b532eef4d23606cbd8b905b37058a00ca5e2e9/fastecdsa-3.0.0.tar.gz",
"platform": null,
"description": "fastecdsa\n=========\n.. image:: https://img.shields.io/pypi/v/fastecdsa.svg\n :target: https://pypi.org/project/fastecdsa/\n :alt: PyPI\n\n.. image:: https://readthedocs.org/projects/fastecdsa/badge/?version=stable\n :target: https://fastecdsa.readthedocs.io/en/stable/?badge=stable\n :alt: Documentation Status\n\n.. contents::\n\nAbout\n-----\nThis is a python package for doing fast elliptic curve cryptography, specifically\ndigital signatures.\n\nSecurity\n--------\nThere is no nonce reuse, no branching on secret material,\nand all points are validated before any operations are performed on them. Timing side challenges\nare mitigated via Montgomery point multiplication. Nonces are generated per RFC6979_. The default\ncurve used throughout the package is P256 which provides 128 bits of security. If you require a\nhigher level of security you can specify the curve parameter in a method to use a curve over a\nbigger field e.g. P384. All that being said, crypto is tricky and I'm not beyond making mistakes.\nPlease use a more established and reviewed library for security critical applications. Open an\nissue or email me if you see any security issue or risk with this library.\n\nPython Versions Supported\n-------------------------\nThe initial release of this package was targeted at python2.7. Earlier versions may work but have\nno guarantee of correctness or stability. As of release 1.2.1+ python3 is supported as well. Due to\npython2's EOL on January 1st 2020 release 2.x of this package only supports python3.5+.\n\nOperating Systems Supported\n---------------------------\nThis package is targeted at the Linux and MacOS operating systems. Due to the the dependency on\nthe GMP C library building this package on Windows is difficult and no official support or\ndistributions are provided for Windows OSes. See issue11_ for what users have done to get things\nbuilding.\n\nSupported Primitives\n--------------------\nCurves over Prime Fields\n~~~~~~~~~~~~~~~~~~~~~~~~\n\n+---------------------------+-----------------------------------------+-------------+\n| Name | Class | Proposed By |\n+===========================+=========================================+=============+\n| P192 / secp192r1 | :code:`fastecdsa.curve.P192` | NIST / NSA |\n+---------------------------+-----------------------------------------+-------------+\n| P224 / secp224r1 | :code:`fastecdsa.curve.P224` | NIST / NSA |\n+---------------------------+-----------------------------------------+-------------+\n| P256 / secp256r1 | :code:`fastecdsa.curve.P256` | NIST / NSA |\n+---------------------------+-----------------------------------------+-------------+\n| P384 / secp384r1 | :code:`fastecdsa.curve.P384` | NIST / NSA |\n+---------------------------+-----------------------------------------+-------------+\n| P521 / secp521r1 | :code:`fastecdsa.curve.P521` | NIST / NSA |\n+---------------------------+-----------------------------------------+-------------+\n| secp192k1 | :code:`fastecdsa.curve.secp192k1` | Certicom |\n+---------------------------+-----------------------------------------+-------------+\n| secp224k1 | :code:`fastecdsa.curve.secp224k1` | Certicom |\n+---------------------------+-----------------------------------------+-------------+\n| secp256k1 (bitcoin curve) | :code:`fastecdsa.curve.secp256k1` | Certicom |\n+---------------------------+-----------------------------------------+-------------+\n| brainpoolP160r1 | :code:`fastecdsa.curve.brainpoolP160r1` | BSI |\n+---------------------------+-----------------------------------------+-------------+\n| brainpoolP192r1 | :code:`fastecdsa.curve.brainpoolP192r1` | BSI |\n+---------------------------+-----------------------------------------+-------------+\n| brainpoolP224r1 | :code:`fastecdsa.curve.brainpoolP224r1` | BSI |\n+---------------------------+-----------------------------------------+-------------+\n| brainpoolP256r1 | :code:`fastecdsa.curve.brainpoolP256r1` | BSI |\n+---------------------------+-----------------------------------------+-------------+\n| brainpoolP320r1 | :code:`fastecdsa.curve.brainpoolP320r1` | BSI |\n+---------------------------+-----------------------------------------+-------------+\n| brainpoolP384r1 | :code:`fastecdsa.curve.brainpoolP384r1` | BSI |\n+---------------------------+-----------------------------------------+-------------+\n| brainpoolP512r1 | :code:`fastecdsa.curve.brainpoolP512r1` | BSI |\n+---------------------------+-----------------------------------------+-------------+\n\nArbitrary Curves\n~~~~~~~~~~~~~~~~\nAs of version 1.5.1 construction of arbitrary curves in Weierstrass form\n(:code:`y^2 = x^3 + ax + b (mod p)`) is supported. I advise against using custom curves for any\nsecurity critical applications. It's up to you to make sure that the parameters you pass here are\ncorrect, no validation of the base point is done, and in general no sanity checks are done. Use\nat your own risk.\n\n.. code:: python\n\n from fastecdsa.curve import Curve\n curve = Curve(\n name, # (str): The name of the curve\n p, # (long): The value of p in the curve equation.\n a, # (long): The value of a in the curve equation.\n b, # (long): The value of b in the curve equation.\n q, # (long): The order of the base point of the curve.\n gx, # (long): The x coordinate of the base point of the curve.\n gy, # (long): The y coordinate of the base point of the curve.\n oid # (str): The object identifier of the curve (optional).\n )\n\nHash Functions\n~~~~~~~~~~~~~~\nAny hash function in the :code:`hashlib` module (:code:`md5, sha1, sha224, sha256, sha384, sha512`)\nwill work, as will any hash function that implements the same interface / core functionality as the\nthose in :code:`hashlib`. For instance, if you wish to use SHA3 as the hash function the\n:code:`pysha3` package will work with this library as long as it is at version >=1.0b1 (as previous\nversions didn't work with the :code:`hmac` module which is used in nonce generation). Note\nthat :code:`sha3_224, sha3_256, sha3_384, sha3_512` are all in :code:`hashlib` as of python3.6.\n\nPerformance\n-----------\n\nCurves over Prime Fields\n~~~~~~~~~~~~~~~~~~~~~~~~\nCurrently it does elliptic curve arithmetic significantly faster than the :code:`ecdsa`\npackage. You can see the times for 1,000 signature and verification operations over\nvarious curves below. These were run on an early 2014 MacBook Air with a 1.4 GHz Intel\nCore i5.\n\n+-----------+------------------------+--------------------+---------+\n| Curve | :code:`fastecdsa` time | :code:`ecdsa` time | Speedup |\n+-----------+------------------------+--------------------+---------+\n| P192 | 3.62s | 1m35.49s | ~26x |\n+-----------+------------------------+--------------------+---------+\n| P224 | 4.50s | 2m13.42s | ~29x |\n+-----------+------------------------+--------------------+---------+\n| P256 | 6.15s | 2m52.43s | ~28x |\n+-----------+------------------------+--------------------+---------+\n| P384 | 12.11s | 6m21.01s | ~31x |\n+-----------+------------------------+--------------------+---------+\n| P521 | 22.21s | 11m39.53s | ~31x |\n+-----------+------------------------+--------------------+---------+\n| secp256k1 | 5.92s | 2m57.19s | ~30x |\n+-----------+------------------------+--------------------+---------+\n\nInstalling\n----------\nYou can use pip: :code:`$ pip install fastecdsa` or clone the repo and use\n:code:`$ python setup.py install`. Note that you need to have a C compiler.\nYou also need to have GMP_ on your system as the underlying\nC code in this package includes the :code:`gmp.h` header (and links against gmp\nvia the :code:`-lgmp` flag). You can install all dependencies as follows:\n\napt\n~~~\n\n.. code:: bash\n\n $ sudo apt-get install python3-dev libgmp3-dev\n\nbrew\n~~~~\n\n.. code:: bash\n\n $ brew install gmp\n\nyum\n~~~\n\n.. code:: bash\n\n $ sudo yum install python-devel gmp-devel\n\nDevelopment\n-----------\nThis package uses :code:`uv` for package management. You can install it via `pip install uv`. First build\nthe C extension modules\n\n.. code:: bash\n\n $ uv run python setup.py build_ext --inplace\n\nTo run the test suite use the following command\n\n.. code:: bash\n\n $ uv run pytest\n\nInstall pre-commit hooks to ensure type checking and autoformatting happens before you commit your code\n\n.. code:: bash\n\n $ uv run pre-commit install\n\nTo build the docs use the following command, which will create a :code:`docs/_build` directory with the\ndocs built as HTML files\n\n.. code:: bash\n\n $ cd docs\n $ uv run make html\n\nPublishing\n~~~~~~~~~~\nNote that currently only the package owner is able to publish releases to PyPI. The following steps\ncan still be used to generate source and wheel distributions, but note that the publish command will\nnot work.\n\nTo build a release first install all supported versions of python into the environment (double check\n:code:`pyproject.toml` for which python versions are supported)\n\n.. code:: bash\n\n $ uv python install 3.9 3.10 3.11 3.12 3.13\n\nThen build a source distribution, followed by wheels for each supported python version\n\n.. code:: bash\n\n $ uv build --sdist\n $ uv build --wheel -p 3.x # do this for each supported python version\n\nThen publish the source and wheels distributions to the test PyPI account.\n\n.. code:: bash\n\n $ uv publish --token {token} --url https://test.pypi.org/simple/\n\nBenchmarking\n------------\nIf you'd like to benchmark performance on your machine you can do so using the command:\n\n.. code:: bash\n\n $ uv run benchmark\n\nThis will use the :code:`timeit` module to benchmark 1000 signature and verification operations\nfor each curve supported by this package. Alternatively, if you have not cloned the repo but\nhave installed the package via e.g. :code:`pip` you can use the following command:\n\n.. code:: bash\n\n $ python -m fastecdsa.benchmark\n\nUsage\n-----\nGenerating Keys\n~~~~~~~~~~~~~~~\nYou can use this package to generate keys if you like. Recall that private keys on elliptic curves\nare integers, and public keys are points i.e. integer pairs.\n\n.. code:: python\n\n from fastecdsa import keys, curve\n\n \"\"\"The reason there are two ways to generate a keypair is that generating the public key requires\n a point multiplication, which can be expensive. That means sometimes you may want to delay\n generating the public key until it is actually needed.\"\"\"\n\n # generate a keypair (i.e. both keys) for curve P256\n priv_key, pub_key = keys.gen_keypair(curve.P256)\n\n # generate a private key for curve P256\n priv_key = keys.gen_private_key(curve.P256)\n\n # get the public key corresponding to the private key we just generated\n pub_key = keys.get_public_key(priv_key, curve.P256)\n\n\nSigning and Verifying\n~~~~~~~~~~~~~~~~~~~~~\nSome basic usage is shown below:\n\n.. code:: python\n\n from fastecdsa import curve, ecdsa, keys\n from hashlib import sha384\n\n m = \"a message to sign via ECDSA\" # some message\n\n ''' use default curve and hash function (P256 and SHA2) '''\n private_key = keys.gen_private_key(curve.P256)\n public_key = keys.get_public_key(private_key, curve.P256)\n # standard signature, returns two integers\n r, s = ecdsa.sign(m, private_key)\n # should return True as the signature we just generated is valid.\n valid = ecdsa.verify((r, s), m, public_key)\n\n ''' specify a different hash function to use with ECDSA '''\n r, s = ecdsa.sign(m, private_key, hashfunc=sha384)\n valid = ecdsa.verify((r, s), m, public_key, hashfunc=sha384)\n\n ''' specify a different curve to use with ECDSA '''\n private_key = keys.gen_private_key(curve.P224)\n public_key = keys.get_public_key(private_key, curve.P224)\n r, s = ecdsa.sign(m, private_key, curve=curve.P224)\n valid = ecdsa.verify((r, s), m, public_key, curve=curve.P224)\n\n ''' using SHA3 via pysha3>=1.0b1 package '''\n import sha3 # pip install [--user] pysha3==1.0b1\n from hashlib import sha3_256\n private_key, public_key = keys.gen_keypair(curve.P256)\n r, s = ecdsa.sign(m, private_key, hashfunc=sha3_256)\n valid = ecdsa.verify((r, s), m, public_key, hashfunc=sha3_256)\n\nArbitrary Elliptic Curve Arithmetic\n~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~\nThe :code:`Point` class allows arbitrary arithmetic to be performed over curves. The two main\noperations are point addition and point multiplication (by a scalar) which can be done via the\nstandard python operators (:code:`+` and :code:`*` respectively):\n\n.. code:: python\n\n # example taken from the document below (section 4.3.2):\n # https://koclab.cs.ucsb.edu/teaching/cren/docs/w02/nist-routines.pdf\n\n from fastecdsa.curve import P256\n from fastecdsa.point import Point\n\n xs = 0xde2444bebc8d36e682edd27e0f271508617519b3221a8fa0b77cab3989da97c9\n ys = 0xc093ae7ff36e5380fc01a5aad1e66659702de80f53cec576b6350b243042a256\n S = Point(xs, ys, curve=P256)\n\n xt = 0x55a8b00f8da1d44e62f6b3b25316212e39540dc861c89575bb8cf92e35e0986b\n yt = 0x5421c3209c2d6c704835d82ac4c3dd90f61a8a52598b9e7ab656e9d8c8b24316\n T = Point(xt, yt, curve=P256)\n\n # Point Addition\n R = S + T\n\n # Point Subtraction: (xs, ys) - (xt, yt) = (xs, ys) + (xt, -yt)\n R = S - T\n\n # Point Doubling\n R = S + S # produces the same value as the operation below\n R = 2 * S # S * 2 works fine too i.e. order doesn't matter\n\n d = 0xc51e4753afdec1e6b6c6a5b992f43f8dd0c7a8933072708b6522468b2ffb06fd\n\n # Scalar Multiplication\n R = d * S # S * d works fine too i.e. order doesn't matter\n\n e = 0xd37f628ece72a462f0145cbefe3f0b355ee8332d37acdd83a358016aea029db7\n\n # Joint Scalar Multiplication\n R = d * S + e * T\n\nImporting and Exporting Keys\n~~~~~~~~~~~~~~~~~~~~~~~~~~~~\nYou can also export keys as files, ASN.1 encoded and formatted per RFC5480_ and RFC5915_. Both\nprivate keys and public keys can be exported as follows:\n\n.. code:: python\n\n from fastecdsa.curve import P256\n from fastecdsa.keys import export_key, gen_keypair\n\n d, Q = gen_keypair(P256)\n # save the private key to disk\n export_key(d, curve=P256, filepath='/path/to/exported/p256.key')\n # save the public key to disk\n export_key(Q, curve=P256, filepath='/path/to/exported/p256.pub')\n\nKeys stored in this format can also be imported. The import function will figure out if the key\nis a public or private key and parse it accordingly:\n\n.. code:: python\n\n from fastecdsa.keys import import_key\n\n # if the file is a private key then parsed_d is a long and parsed_Q is a Point object\n # if the file is a public key then parsed_d will be None\n parsed_d, parsed_Q = import_key('/path/to/file.key')\n\nOther encoding formats can also be specified, such as SEC1_ for public keys. This is done using\nclasses found in the :code:`fastecdsa.encoding` package, and passing them as keyword args to\nthe key functions:\n\n.. code:: python\n\n from fastecdsa.curve import P256\n from fastecdsa.encoding.sec1 import SEC1Encoder\n from fastecdsa.keys import export_key, gen_keypair, import_key\n\n _, Q = gen_keypair(P256)\n export_key(Q, curve=P256, filepath='/path/to/p256.key', encoder=SEC1Encoder)\n parsed_Q = import_key('/path/to/p256.key', curve=P256, public=True, decoder=SEC1Encoder)\n\nEncoding Signatures\n~~~~~~~~~~~~~~~~~~~\nDER encoding of ECDSA signatures as defined in RFC2459_ is also supported. The\n:code:`fastecdsa.encoding.der` provides the :code:`DEREncoder` class which encodes signatures:\n\n.. code:: python\n\n from fastecdsa.encoding.der import DEREncoder\n\n r, s = 0xdeadc0de, 0xbadc0de\n encoded = DEREncoder.encode_signature(r, s)\n decoded_r, decoded_s = DEREncoder.decode_signature(encoded)\n\nAcknowledgements\n----------------\nThanks to those below for contributing improvements:\n\n- boneyard93501\n- clouds56\n- m-kus\n- sirk390\n- targon\n- NotStatilko\n- bbbrumley\n- luinxz\n- JJChiDguez\n- J08nY\n- trevor-crypto\n- sylvainpelissier\n- akaIDIOT\n\n.. _issue11: https://github.com/AntonKueltz/fastecdsa/issues/11\n.. _GMP: https://gmplib.org/\n.. _RFC2459: https://tools.ietf.org/html/rfc2459\n.. _RFC5480: https://tools.ietf.org/html/rfc5480\n.. _RFC5915: https://tools.ietf.org/html/rfc5915\n.. _RFC6979: https://tools.ietf.org/html/rfc6979\n.. _SEC1: http://www.secg.org/sec1-v2.pdf\n",
"bugtrack_url": null,
"license": "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/> ",
"summary": "Fast elliptic curve digital signatures",
"version": "3.0.0",
"project_urls": {
"docs": "https://fastecdsa.readthedocs.io",
"pypi": "https://pypi.org/project/fastecdsa/",
"repo": "https://github.com/AntonKueltz/fastecdsa"
},
"split_keywords": [
"elliptic",
" curve",
" cryptography",
" ecdsa",
" ecc"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "73ea5bb3fbc7c0368bd68da4f3aefbeb4f5964ebb3d3db9268474f24261e5648",
"md5": "1991bfc9a6bea8be1a3f87e7bd949ee4",
"sha256": "880ff57d65a013e4972e07d1d11e4a3b7018ff1f54330d697c41318b8d341e56"
},
"downloads": -1,
"filename": "fastecdsa-3.0.0-cp310-cp310-macosx_13_0_x86_64.whl",
"has_sig": false,
"md5_digest": "1991bfc9a6bea8be1a3f87e7bd949ee4",
"packagetype": "bdist_wheel",
"python_version": "cp310",
"requires_python": ">=3.9",
"size": 275171,
"upload_time": "2025-01-01T16:38:19",
"upload_time_iso_8601": "2025-01-01T16:38:19.009268Z",
"url": "https://files.pythonhosted.org/packages/73/ea/5bb3fbc7c0368bd68da4f3aefbeb4f5964ebb3d3db9268474f24261e5648/fastecdsa-3.0.0-cp310-cp310-macosx_13_0_x86_64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "af62525f3b5b9f85729690be4f890784bee75a95a4ceb67b38414f76a62c077f",
"md5": "d1d11a52d891042fa03dc95769d25ca5",
"sha256": "da385678eed4156f174ecd862935c27c4860b663ad744e0b6cdeb82e68944ca5"
},
"downloads": -1,
"filename": "fastecdsa-3.0.0-cp310-cp310-macosx_14_0_arm64.whl",
"has_sig": false,
"md5_digest": "d1d11a52d891042fa03dc95769d25ca5",
"packagetype": "bdist_wheel",
"python_version": "cp310",
"requires_python": ">=3.9",
"size": 255672,
"upload_time": "2025-01-01T16:38:21",
"upload_time_iso_8601": "2025-01-01T16:38:21.604764Z",
"url": "https://files.pythonhosted.org/packages/af/62/525f3b5b9f85729690be4f890784bee75a95a4ceb67b38414f76a62c077f/fastecdsa-3.0.0-cp310-cp310-macosx_14_0_arm64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "aa24a8ccc69a1dd704fed09e9d4ee70f4bbd0e08433281e097e1462915bd40d3",
"md5": "7c657fda3510d3fbae6eaa3c27ab8ea9",
"sha256": "b138eafec6f1a5b230919eecb24d7bf02e6d4e855c21b67ff03c5f31770d79f5"
},
"downloads": -1,
"filename": "fastecdsa-3.0.0-cp310-cp310-manylinux_2_17_i686.manylinux2014_i686.whl",
"has_sig": false,
"md5_digest": "7c657fda3510d3fbae6eaa3c27ab8ea9",
"packagetype": "bdist_wheel",
"python_version": "cp310",
"requires_python": ">=3.9",
"size": 306914,
"upload_time": "2025-01-01T16:38:24",
"upload_time_iso_8601": "2025-01-01T16:38:24.358200Z",
"url": "https://files.pythonhosted.org/packages/aa/24/a8ccc69a1dd704fed09e9d4ee70f4bbd0e08433281e097e1462915bd40d3/fastecdsa-3.0.0-cp310-cp310-manylinux_2_17_i686.manylinux2014_i686.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "e29bffeb6ec9d3309d35e5c7bbbe6e5bef8281fe713fabdd6369843f51ce799d",
"md5": "d1ad02d49ad802b1576827ed40304aa2",
"sha256": "edce38b30a0f56bd4a4bc9a15ac581b788e89528f72487dcecb3cfaa4c119d0c"
},
"downloads": -1,
"filename": "fastecdsa-3.0.0-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl",
"has_sig": false,
"md5_digest": "d1ad02d49ad802b1576827ed40304aa2",
"packagetype": "bdist_wheel",
"python_version": "cp310",
"requires_python": ">=3.9",
"size": 329343,
"upload_time": "2025-01-01T16:38:28",
"upload_time_iso_8601": "2025-01-01T16:38:28.472411Z",
"url": "https://files.pythonhosted.org/packages/e2/9b/ffeb6ec9d3309d35e5c7bbbe6e5bef8281fe713fabdd6369843f51ce799d/fastecdsa-3.0.0-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "3b09b8890635d34373c01795ecac12352b1ab538e6bdea417e433c542e434861",
"md5": "f9b3a5370e43fc2ef47a73b8acf02703",
"sha256": "f06dde8fb204bbf9ea5412c03873cc0191891212743777f21c31f4e862188c9e"
},
"downloads": -1,
"filename": "fastecdsa-3.0.0-cp311-cp311-macosx_13_0_x86_64.whl",
"has_sig": false,
"md5_digest": "f9b3a5370e43fc2ef47a73b8acf02703",
"packagetype": "bdist_wheel",
"python_version": "cp311",
"requires_python": ">=3.9",
"size": 275167,
"upload_time": "2025-01-01T16:38:30",
"upload_time_iso_8601": "2025-01-01T16:38:30.253443Z",
"url": "https://files.pythonhosted.org/packages/3b/09/b8890635d34373c01795ecac12352b1ab538e6bdea417e433c542e434861/fastecdsa-3.0.0-cp311-cp311-macosx_13_0_x86_64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "3e53e441d12bd0879b24f63d285f0b47e37d119bd59d2e466497875d0c1b6b49",
"md5": "6b5e9fa32c6630be219a7aa0cfd9325a",
"sha256": "0344e370a29791b70d5f8da5f676ef37302b7a36f39620a6389bce36b798fbef"
},
"downloads": -1,
"filename": "fastecdsa-3.0.0-cp311-cp311-macosx_14_0_arm64.whl",
"has_sig": false,
"md5_digest": "6b5e9fa32c6630be219a7aa0cfd9325a",
"packagetype": "bdist_wheel",
"python_version": "cp311",
"requires_python": ">=3.9",
"size": 255674,
"upload_time": "2025-01-01T16:38:32",
"upload_time_iso_8601": "2025-01-01T16:38:32.103704Z",
"url": "https://files.pythonhosted.org/packages/3e/53/e441d12bd0879b24f63d285f0b47e37d119bd59d2e466497875d0c1b6b49/fastecdsa-3.0.0-cp311-cp311-macosx_14_0_arm64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "451306270400dbc237d0d258eb914ca47e11792c6058006364b26e0137eb038d",
"md5": "409ad9c749b8d5feb8ffcad0fccac799",
"sha256": "57bd85a664c1fcd5c5b7963c0123e7a58d40db1f18957cd8720a301f0ad990b8"
},
"downloads": -1,
"filename": "fastecdsa-3.0.0-cp311-cp311-manylinux_2_17_i686.manylinux2014_i686.whl",
"has_sig": false,
"md5_digest": "409ad9c749b8d5feb8ffcad0fccac799",
"packagetype": "bdist_wheel",
"python_version": "cp311",
"requires_python": ">=3.9",
"size": 308479,
"upload_time": "2025-01-01T16:38:33",
"upload_time_iso_8601": "2025-01-01T16:38:33.582247Z",
"url": "https://files.pythonhosted.org/packages/45/13/06270400dbc237d0d258eb914ca47e11792c6058006364b26e0137eb038d/fastecdsa-3.0.0-cp311-cp311-manylinux_2_17_i686.manylinux2014_i686.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "3ad88eff796828555463d7d0072edd98e69deca69b25a5466bd168cdec07f02e",
"md5": "5aa2ccae8802b0de2965782dd7178ca0",
"sha256": "dc3233e60c24b3f207dd02ec9edc2acef2507a473986fe2a5c35c41e5af5fd95"
},
"downloads": -1,
"filename": "fastecdsa-3.0.0-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl",
"has_sig": false,
"md5_digest": "5aa2ccae8802b0de2965782dd7178ca0",
"packagetype": "bdist_wheel",
"python_version": "cp311",
"requires_python": ">=3.9",
"size": 329461,
"upload_time": "2025-01-01T16:38:35",
"upload_time_iso_8601": "2025-01-01T16:38:35.521059Z",
"url": "https://files.pythonhosted.org/packages/3a/d8/8eff796828555463d7d0072edd98e69deca69b25a5466bd168cdec07f02e/fastecdsa-3.0.0-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "c74dc58707d7f351cf742a1ceca797c34c3a8025aba7ad462fd267e77e0ac51b",
"md5": "98b914e3fd44a4a57a108037ef1a5608",
"sha256": "b3fd728a64379e6e47b242262a770cc8212b718504d58661e9edb74a51dd01b4"
},
"downloads": -1,
"filename": "fastecdsa-3.0.0-cp312-cp312-macosx_13_0_x86_64.whl",
"has_sig": false,
"md5_digest": "98b914e3fd44a4a57a108037ef1a5608",
"packagetype": "bdist_wheel",
"python_version": "cp312",
"requires_python": ">=3.9",
"size": 275171,
"upload_time": "2025-01-01T16:38:37",
"upload_time_iso_8601": "2025-01-01T16:38:37.526606Z",
"url": "https://files.pythonhosted.org/packages/c7/4d/c58707d7f351cf742a1ceca797c34c3a8025aba7ad462fd267e77e0ac51b/fastecdsa-3.0.0-cp312-cp312-macosx_13_0_x86_64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "8e2693b9dd1624e436ee09f6a3d0fdde94fe5f92f84f0f35f6071fbfe7a5ea18",
"md5": "ab16f30de2c5e58765bc0fdb2ae40a36",
"sha256": "dcd2ab0eaa9d03cf4298a4de2642f482fc5128ad8fc495294004fe7f7c5fe4c3"
},
"downloads": -1,
"filename": "fastecdsa-3.0.0-cp312-cp312-macosx_14_0_arm64.whl",
"has_sig": false,
"md5_digest": "ab16f30de2c5e58765bc0fdb2ae40a36",
"packagetype": "bdist_wheel",
"python_version": "cp312",
"requires_python": ">=3.9",
"size": 255674,
"upload_time": "2025-01-01T16:38:39",
"upload_time_iso_8601": "2025-01-01T16:38:39.893949Z",
"url": "https://files.pythonhosted.org/packages/8e/26/93b9dd1624e436ee09f6a3d0fdde94fe5f92f84f0f35f6071fbfe7a5ea18/fastecdsa-3.0.0-cp312-cp312-macosx_14_0_arm64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "28e98971aa6a8c9df68c928f9883e045dca0e28993626a0aa807b44561651567",
"md5": "b2b2242c9868cb97d0bbc0d1b0049c9a",
"sha256": "f3198f8d7ab969ed32466e7535257819374771a5860fe552e9d591a8ccfd9bbc"
},
"downloads": -1,
"filename": "fastecdsa-3.0.0-cp312-cp312-manylinux_2_17_i686.manylinux2014_i686.whl",
"has_sig": false,
"md5_digest": "b2b2242c9868cb97d0bbc0d1b0049c9a",
"packagetype": "bdist_wheel",
"python_version": "cp312",
"requires_python": ">=3.9",
"size": 308792,
"upload_time": "2025-01-01T16:38:42",
"upload_time_iso_8601": "2025-01-01T16:38:42.077197Z",
"url": "https://files.pythonhosted.org/packages/28/e9/8971aa6a8c9df68c928f9883e045dca0e28993626a0aa807b44561651567/fastecdsa-3.0.0-cp312-cp312-manylinux_2_17_i686.manylinux2014_i686.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "c5306257386f218897ea53241ecd27580c79dd5196481f333d4d8f6f82a2fd44",
"md5": "ee23c88df03d8dbd91e6b88ac57a551a",
"sha256": "65884560ea0bee4a2ad4bbee1b19896f99c05ece7b595d78755aff6a49028305"
},
"downloads": -1,
"filename": "fastecdsa-3.0.0-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.whl",
"has_sig": false,
"md5_digest": "ee23c88df03d8dbd91e6b88ac57a551a",
"packagetype": "bdist_wheel",
"python_version": "cp312",
"requires_python": ">=3.9",
"size": 329575,
"upload_time": "2025-01-01T16:38:43",
"upload_time_iso_8601": "2025-01-01T16:38:43.453175Z",
"url": "https://files.pythonhosted.org/packages/c5/30/6257386f218897ea53241ecd27580c79dd5196481f333d4d8f6f82a2fd44/fastecdsa-3.0.0-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "f0d09f99c32c6f53e65636eb619176f547c7aad43c6693b146e4a6b633c61b3a",
"md5": "afbef4708cdff7023689c11bc608e89b",
"sha256": "50ddc3c224b92ecfa90e7f8bec59bbd3c61817278bf7d06bb6f7ad4d4bffa634"
},
"downloads": -1,
"filename": "fastecdsa-3.0.0-cp313-cp313-macosx_13_0_x86_64.whl",
"has_sig": false,
"md5_digest": "afbef4708cdff7023689c11bc608e89b",
"packagetype": "bdist_wheel",
"python_version": "cp313",
"requires_python": ">=3.9",
"size": 275184,
"upload_time": "2025-01-01T16:38:44",
"upload_time_iso_8601": "2025-01-01T16:38:44.883969Z",
"url": "https://files.pythonhosted.org/packages/f0/d0/9f99c32c6f53e65636eb619176f547c7aad43c6693b146e4a6b633c61b3a/fastecdsa-3.0.0-cp313-cp313-macosx_13_0_x86_64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "68c6bd10a044f2cd927b82a2bfb8ad8a3aee8a37ac3f368bb38b67caf627fd96",
"md5": "83c12e724d2b9497556abba2f88c78e3",
"sha256": "76a6e32daf255ff7d8d7626e15ff68e6de2ce71727ffbecd38d43b52fec8768b"
},
"downloads": -1,
"filename": "fastecdsa-3.0.0-cp313-cp313-macosx_14_0_arm64.whl",
"has_sig": false,
"md5_digest": "83c12e724d2b9497556abba2f88c78e3",
"packagetype": "bdist_wheel",
"python_version": "cp313",
"requires_python": ">=3.9",
"size": 255691,
"upload_time": "2025-01-01T16:38:46",
"upload_time_iso_8601": "2025-01-01T16:38:46.623471Z",
"url": "https://files.pythonhosted.org/packages/68/c6/bd10a044f2cd927b82a2bfb8ad8a3aee8a37ac3f368bb38b67caf627fd96/fastecdsa-3.0.0-cp313-cp313-macosx_14_0_arm64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "8a8ea7e6a308aeff325ba1c76dafecd469d6bf2c3a1672997091aaacfd4a6da7",
"md5": "0e7a6876b46bae24433434727379323e",
"sha256": "27a7b2179794da7dab23873cda6839bdd4cc22c0135dc8fd6b24e81e08a02836"
},
"downloads": -1,
"filename": "fastecdsa-3.0.0-cp313-cp313-manylinux_2_17_i686.manylinux2014_i686.whl",
"has_sig": false,
"md5_digest": "0e7a6876b46bae24433434727379323e",
"packagetype": "bdist_wheel",
"python_version": "cp313",
"requires_python": ">=3.9",
"size": 308569,
"upload_time": "2025-01-01T16:38:48",
"upload_time_iso_8601": "2025-01-01T16:38:48.426512Z",
"url": "https://files.pythonhosted.org/packages/8a/8e/a7e6a308aeff325ba1c76dafecd469d6bf2c3a1672997091aaacfd4a6da7/fastecdsa-3.0.0-cp313-cp313-manylinux_2_17_i686.manylinux2014_i686.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "7387702be1b454ec1e217bfdb959fdbe256b0197a858e2b28741d2d80fe4b85c",
"md5": "2110d149b2a3808b3848b6a11ebb6037",
"sha256": "0a7a14a5881be5ba9a6eefd7ca5e9767cec9fedfec8b17d5f1bf5db0cb8b0467"
},
"downloads": -1,
"filename": "fastecdsa-3.0.0-cp313-cp313-manylinux_2_17_x86_64.manylinux2014_x86_64.whl",
"has_sig": false,
"md5_digest": "2110d149b2a3808b3848b6a11ebb6037",
"packagetype": "bdist_wheel",
"python_version": "cp313",
"requires_python": ">=3.9",
"size": 329618,
"upload_time": "2025-01-01T16:38:50",
"upload_time_iso_8601": "2025-01-01T16:38:50.338879Z",
"url": "https://files.pythonhosted.org/packages/73/87/702be1b454ec1e217bfdb959fdbe256b0197a858e2b28741d2d80fe4b85c/fastecdsa-3.0.0-cp313-cp313-manylinux_2_17_x86_64.manylinux2014_x86_64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "1b2386e847ff8b195b0c9c5618b4dba7cadb62efee22063eb7c8428fe329aa24",
"md5": "1805dda36962c8beef329357f8cd5421",
"sha256": "b579bed100af511de236639aad3145489926bf505466da8940cd041d76e47b6d"
},
"downloads": -1,
"filename": "fastecdsa-3.0.0-cp39-cp39-macosx_13_0_x86_64.whl",
"has_sig": false,
"md5_digest": "1805dda36962c8beef329357f8cd5421",
"packagetype": "bdist_wheel",
"python_version": "cp39",
"requires_python": ">=3.9",
"size": 275160,
"upload_time": "2025-01-01T16:38:51",
"upload_time_iso_8601": "2025-01-01T16:38:51.760414Z",
"url": "https://files.pythonhosted.org/packages/1b/23/86e847ff8b195b0c9c5618b4dba7cadb62efee22063eb7c8428fe329aa24/fastecdsa-3.0.0-cp39-cp39-macosx_13_0_x86_64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "5d9f4703f565e8214fa6b6f9af04e5f4cf232d591ad4b850f56506e7276f7446",
"md5": "2fe8aada843ce94cb2970e27cfac049b",
"sha256": "1a7be23be3de6c47c1684ecc1d8db551080168ee6deb8624c854508cd23d94ce"
},
"downloads": -1,
"filename": "fastecdsa-3.0.0-cp39-cp39-macosx_14_0_arm64.whl",
"has_sig": false,
"md5_digest": "2fe8aada843ce94cb2970e27cfac049b",
"packagetype": "bdist_wheel",
"python_version": "cp39",
"requires_python": ">=3.9",
"size": 255667,
"upload_time": "2025-01-01T16:38:54",
"upload_time_iso_8601": "2025-01-01T16:38:54.609133Z",
"url": "https://files.pythonhosted.org/packages/5d/9f/4703f565e8214fa6b6f9af04e5f4cf232d591ad4b850f56506e7276f7446/fastecdsa-3.0.0-cp39-cp39-macosx_14_0_arm64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "de5fd3796d9186d8d85333bf438af881d34604045c1b4ca952d20fd5f15b2791",
"md5": "9582f3b43bed356faf30b984d6ede8b7",
"sha256": "721e8cae31c9609216735b2267983a38159f12d0d7da2e3b1947dd4c1241b105"
},
"downloads": -1,
"filename": "fastecdsa-3.0.0-cp39-cp39-manylinux_2_17_i686.manylinux2014_i686.whl",
"has_sig": false,
"md5_digest": "9582f3b43bed356faf30b984d6ede8b7",
"packagetype": "bdist_wheel",
"python_version": "cp39",
"requires_python": ">=3.9",
"size": 306607,
"upload_time": "2025-01-01T16:38:56",
"upload_time_iso_8601": "2025-01-01T16:38:56.152976Z",
"url": "https://files.pythonhosted.org/packages/de/5f/d3796d9186d8d85333bf438af881d34604045c1b4ca952d20fd5f15b2791/fastecdsa-3.0.0-cp39-cp39-manylinux_2_17_i686.manylinux2014_i686.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "477ae65bb38e6482bf15cb0285af24996bd94b5f9c2a2ba32875f0238cbd0be6",
"md5": "4fc06d7a6fa3218befb748fc2b08e109",
"sha256": "6ae6a67fb73d54f949e3b5b786025e45638e0eab8e5d5197a59be21ee30c53b7"
},
"downloads": -1,
"filename": "fastecdsa-3.0.0-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl",
"has_sig": false,
"md5_digest": "4fc06d7a6fa3218befb748fc2b08e109",
"packagetype": "bdist_wheel",
"python_version": "cp39",
"requires_python": ">=3.9",
"size": 328943,
"upload_time": "2025-01-01T16:38:57",
"upload_time_iso_8601": "2025-01-01T16:38:57.710666Z",
"url": "https://files.pythonhosted.org/packages/47/7a/e65bb38e6482bf15cb0285af24996bd94b5f9c2a2ba32875f0238cbd0be6/fastecdsa-3.0.0-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "dc4c343b2fba2e66d1b476a2f5b532eef4d23606cbd8b905b37058a00ca5e2e9",
"md5": "4c66f6af7d537a169c51419cccea8286",
"sha256": "75e3a7c1962f8ed38ca6cf747e9ece51fcdb3310c5b24d0e8fbda01683329805"
},
"downloads": -1,
"filename": "fastecdsa-3.0.0.tar.gz",
"has_sig": false,
"md5_digest": "4c66f6af7d537a169c51419cccea8286",
"packagetype": "sdist",
"python_version": "source",
"requires_python": ">=3.9",
"size": 47548,
"upload_time": "2025-01-01T16:38:59",
"upload_time_iso_8601": "2025-01-01T16:38:59.143657Z",
"url": "https://files.pythonhosted.org/packages/dc/4c/343b2fba2e66d1b476a2f5b532eef4d23606cbd8b905b37058a00ca5e2e9/fastecdsa-3.0.0.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2025-01-01 16:38:59",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "AntonKueltz",
"github_project": "fastecdsa",
"travis_ci": false,
"coveralls": false,
"github_actions": true,
"lcname": "fastecdsa"
}