Deprecated

In favour of

cipher-aes

Fast AES cipher implementation with advanced mode of operations

https://github.com/vincenthz/hs-cipher-aes

LTS Haskell 22.13:0.2.11
Stackage Nightly 2024-03-14:0.2.11
Latest on Hackage:0.2.11

See all snapshots cipher-aes appears in

BSD-3-Clause licensed and maintained by Vincent Hanquez
This version can be pinned in stack with:cipher-aes-0.2.11@sha256:3f887a53efb0df216d44e954108fd660a7548e6f109bba1f158cc2c792810f8b,3202

Module documentation for 0.2.11

Fast AES cipher implementation with advanced mode of operations.

The modes of operations available are ECB (Electronic code book), CBC (Cipher block chaining), CTR (Counter), XTS (XEX with ciphertext stealing), GCM (Galois Counter Mode).

The AES implementation uses AES-NI when available (on x86 and x86-64 architecture), but fallback gracefully to a software C implementation.

The software implementation uses S-Boxes, which might suffer for cache timing issues. However do notes that most other known software implementations, including very popular one (openssl, gnutls) also uses similar implementation. If it matters for your case, you should make sure you have AES-NI available, or you'll need to use a different implementation.