@crema-labs/aes-circom
v0.0.2
Published
A generic AES forward cipher implementation
Downloads
11
Readme
aes-circom
This repository contains generic implementation for AES encryption in Circom.
AES
AES is a symmetric encryption algorithm that was established by the U.S. National Institute of Standards and Technology (NIST) in 2001. It is a subset of the Rijndael block cipher. AES has a fixed block size of 128 bits and a key size of 128, 192, or 256 bits. The algorithm is based on a design principle known as a substitution-permutation network (SPN). Read more about AES here := FIPS 197. Simple Rust implementation of AES can be found here := tinyaes
Circuit
The circuits contain components for AES forward encryption. The implementation strictly follows the AES standard mentioned in the FIPS 197 document. The circuit is designed to be generic and can be used for any key size (128, 192, 256 bits) and block size (128 bits).
Check the Cipher and KeyExpansion circuits for visual representation of the design.
Constraints
The following constraint values were calculated using
circom -l node_modules ./circuits/main/cipher_4.circom -o build --r1cs --wasm
Design Decisions
The circuit only support the forward encryption of AES as we believe that the proof of computation for any proprietary use case can be refactored to use the forward encryption instead of the decryption.
💡 Create an issue if you think that the decryption circuit is necessary.
Circomkit
In this repository, we are using Circomkit to test some example circuits using Mocha. The circuits and the statements that they prove are as follows:
Configuration
Circomkit checks for circomkit.json
to override it's default configurations. We could for example change the target version, prime field and the proof system by setting circomkit.json
to be:
{
"version": "2.1.8",
"protocol": "plonk",
"prime": "bls12381"
}
Testing
You can use the following commands to test the circuits:
# test everything
yarn test
# test a specific circuit
yarn test -g <template-name>
Roadmap
- [x] AES Forward Encryption Circuit
- [ ] Add AES-CTR mode (priority for ECIES implementaion)
- [ ] Add all other modes adhering to NIST standards
Contribution
Feel free to contribute to this repository by creating issues or pull requests. We are open to any suggestions or improvements.