Skip to content

Commit

Permalink
Merge pull request theupdateframework#1054 from jku/update-docs-on-cr…
Browse files Browse the repository at this point in the history
…ypto-details

Update docs on crypto details
  • Loading branch information
lukpueh authored Jun 23, 2020
2 parents 017a5ff + dc78d89 commit 5d16f91
Show file tree
Hide file tree
Showing 2 changed files with 15 additions and 18 deletions.
24 changes: 12 additions & 12 deletions docs/TUTORIAL.md
Original file line number Diff line number Diff line change
Expand Up @@ -65,25 +65,25 @@ updates.
The repository tool supports multiple public-key algorithms, such as
[RSA](https://en.wikipedia.org/wiki/RSA_%28cryptosystem%29) and
[Ed25519](https://ed25519.cr.yp.to/), and multiple cryptography libraries.
Which cryptography library to use is determined by the default, or user modified,
settings in [settings.py](../tuf/settings.py).

The [PyCrypto](https://www.dlitz.net/software/pycrypto/) library may be
selected to generate RSA keys and
[RSA-PSS](https://en.wikipedia.org/wiki/RSA-PSS) signatures. If generation of
Ed25519 signatures is needed, the [PyNaCl](https://github.com/pyca/pynacl)
library setting should be enabled. PyNaCl is a Python binding to the
Networking and Cryptography Library. For key storage, RSA keys may be stored
in PEM or JSON format, and Ed25519 keys in JSON format. Private keys, for both
RSA and Ed25519, are encrypted and passphrase-protected (strengthened with

Using [RSA-PSS](https://tools.ietf.org/html/rfc8017#section-8.1) or
[ECDSA](https://en.wikipedia.org/wiki/Elliptic_Curve_Digital_Signature_Algorithm)
signatures requires the [cryptography](https://cryptography.io/) library. If
generation of Ed25519 signatures is needed
[PyNaCl](https://github.com/pyca/pynacl) library should be installed. This
tutorial assumes both dependencies are installed: refer to
[Installation Instructions](INSTALLATION.rst#install-with-more-cryptographic-flexibility)
for details.

The Ed25519 and ECDSA keys are stored in JSON format and RSA keys are stored in PEM
format. Private keys are encrypted and passphrase-protected (strengthened with
PBKDF2-HMAC-SHA256.) Generating, importing, and loading cryptographic key
files can be done with functions available in the repository tool.

To start, a public and private RSA key pair is generated with the
`generate_and_write_rsa_keypair()` function. The keys generated next are
needed to sign the repository metadata files created in upcoming sub-sections.


Note: In the instructions below, lines that start with `>>>` denote commands
that should be entered by the reader, `#` begins the start of a comment, and
text without prepended symbols is the output of a command.
Expand Down
9 changes: 3 additions & 6 deletions setup.py
Original file line number Diff line number Diff line change
Expand Up @@ -40,12 +40,9 @@
$ pip install .
# Installing optional requirements (i.e., after installing tuf).
# The 'tools' optional requirement is currently supported, which enables
# fast and secure ed25519 key generation, and signature verification
# computations with PyNaCl+libsodium. General-purpose cryptography is also
# provided. 'tools' is needed by the TUF repository tools. Clients that
# require verification of RSASSA-PSS signatures must also install tuf[tools].
$ pip install tuf[tools]
# Support for creation of Ed25519 signatures and support for RSA and ECDSA
# signatures in general requires optional dependencies:
$ pip install securesystemslib[crypto,pynacl]
Alternate installation options:
Expand Down

0 comments on commit 5d16f91

Please sign in to comment.