Todo List

Feel free to take one of these on if it interests you. Before starting out on something, send an email to the dev list or open a discussion ticket on GitHub to make sure you’re on the right track.

Request a new feature by opening a pull request to update this file.

New Ciphers/Hashes/MACs

Improved Ciphers Implementations

  • Stiched AES/GCM mode for CPUs supporting both AES and CLMUL

  • Combine AES-NI, ARMv8 and POWER AES implementations (as already done for CLMUL)

  • Support for VAES (Zen4/Ice Lake)

  • NEON/VMX support for the SIMD based GHASH

  • Vector permute AES only supports little-endian systems; fix for big-endian

  • SM4 using AES-NI (https://github.com/mjosaarinen/sm4ni) or vector permute

  • Poly1305 using AVX2

  • SHA-512 using BMI2+AVX2

  • Constant time bitsliced DES

  • SIMD evaluation of SHA-2 and SHA-3 compression functions

  • Improved Salsa implementations (SIMD_4x32 and/or AVX2)

  • Add CLMUL/PMULL implementations for CRC24/CRC32

Public Key Crypto, Math

  • Short vector optimization for BigInt

  • BLS12-381 pairing, BLS signatures

  • Identity based encryption

  • Paillier homomorphic cryptosystem

  • New PAKEs (pending CFRG bakeoff results)

  • SPHINX password store (https://eprint.iacr.org/2018/695)

Utility Functions

  • Make Memory_Pool more concurrent (currently uses a global lock)

  • Guarded integer type to prevent overflow bugs

External Providers, Hardware Support

  • Add support for ARMv8.4-A SHA-3, SM3 and RNG instructions

  • Aarch64 inline asm for mp

  • /dev/crypto provider (ciphers, hashes)

  • Windows CryptoNG provider (ciphers, hashes)

  • Extend Apple CommonCrypto provider (HMAC, CMAC, RSA, ECDSA, ECDH)

  • Add support for iOS keychain access

  • POWER8 SHA-2 extensions (GH #1486 + #1487)

  • Add support for VPSUM on big-endian PPC64 (GH #2252)

TLS

  • Make DTLS support optional at build time

  • Improve/optimize DTLS defragmentation and retransmission

  • Make RSA optional at build time

  • Make finite field DH optional at build time

  • Certificate Transparency extensions

  • TLS supplemental authorization data (RFC 4680, RFC 5878)

  • DTLS-SCTP (RFC 6083)

PKIX

  • Further tests of validation API (see GH #785)

  • Test suite for validation of ‘real world’ cert chains (GH #611)

  • X.509 policy constraints

  • OCSP responder logic

New Protocols / Formats

  • Noise protocol

  • ACME protocol (needs a story for JSON)

  • Cryptographic Message Syntax (RFC 5652)

  • Fernet symmetric encryption (https://cryptography.io/en/latest/fernet/)

  • RNCryptor format (https://github.com/RNCryptor/RNCryptor)

  • Age format (https://age-encryption.org/v1)

  • Useful OpenPGP subset 1: symmetrically encrypted files. Not aiming to process arbitrary OpenPGP, but rather produce something that happens to be readable by gpg and is relatively simple to process for decryption. Require AEAD mode (EAX/OCB).

  • Useful OpenPGP subset 2: Process OpenPGP public keys

  • Useful OpenPGP subset 3: Verification of OpenPGP signatures

Cleanups

  • Unicode path support on Windows (GH #1615)

  • The X.509 path validation tests have much duplicated logic

New C APIs

  • PKCS10 requests

  • Certificate signing

  • CRLs

  • Expose TLS

  • Expose secret sharing

  • Expose deterministic PRNG

  • base32

  • base58

  • DL_Group

  • EC_Group

Build/Test

  • Support hardcoding all test vectors into the botan-test binary so it can run as a standalone item (copied to a device, etc)

  • Run iOS binary under simulator in CI

  • Run Android binary under simulator in CI

  • Add support for vxWorks

CLI

  • Add a --completion option to dump autocomplete info, write support for autocompletion in bash/zsh.

  • Refactor speed

  • Change tls_server to be a tty<->socket app, like tls_client is, instead of a bogus echo server.

  • encrypt / decrypt tools providing password based file encryption

  • Add ECM factoring

  • Clone of minisign signature utility

  • Password store utility

  • TOTP calculator

  • Clone of magic wormhole

  • ACVP client (https://github.com/usnistgov/ACVP)

Documentation

  • Always needs help