Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/lanfordcai/silicon
A wrapper of Elixir/Erlang crypto packages. Lots of extra test cases added.
https://github.com/lanfordcai/silicon
aes blake2b ed25519 keccak secp256k1 sha3
Last synced: 2 months ago
JSON representation
A wrapper of Elixir/Erlang crypto packages. Lots of extra test cases added.
- Host: GitHub
- URL: https://github.com/lanfordcai/silicon
- Owner: LanfordCai
- License: mit
- Created: 2019-03-23T09:35:33.000Z (almost 6 years ago)
- Default Branch: master
- Last Pushed: 2019-06-11T15:47:03.000Z (over 5 years ago)
- Last Synced: 2024-09-23T11:47:28.814Z (3 months ago)
- Topics: aes, blake2b, ed25519, keccak, secp256k1, sha3
- Language: Elixir
- Homepage:
- Size: 16.5 MB
- Stars: 2
- Watchers: 3
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Silicon
Silicon is another wrapper of Elixir/Erlang crypto packages.
### Installation
The package can be installed by adding `silicon` to your list of dependencies in `mix.exs`:
```elixir
def deps do
[
{:silicon, "~> 0.1.0"}
]
end
```The docs can be found at [https://hexdocs.pm/silicon](https://hexdocs.pm/silicon).
### Packages
We wrapped the packages below:
* `{:libdecaf, "~> 1.0"}` for Ed25519 and SHA3
* `{:keccakf1600, "~> 2.0", hex: :keccakf1600_orig}` for Keccak Origin
* `{:libsecp256k1, "~> 0.1.10"}` for Secp256k1
* `{:blake2_elixir, git: "https://github.com/riverrun/blake2_elixir.git"}` for Blake2b
* `:crypto` for others### Test Vectors
We added lots of extra test vectors to test against the methods exposed by silicon#### AES Test Vectors
* AES-CBC: `https://csrc.nist.gov/projects/cryptographic-algorithm-validation-program/block-ciphers#AES`
* AES-CBC-PKCS7: `https://raw.githubusercontent.com/google/wycheproof/master/testvectors/aes_cbc_pkcs5_test.json`
* AES-GCM: `https://csrc.nist.gov/Projects/Cryptographic-Algorithm-Validation-Program/CAVP-TESTING-BLOCK-CIPHER-MODES#GCMVS`
* AES-CTR: Got from `https://github.com/pyca/cryptography`, which is the test vectors from RFC 3686#### Hash Function Test Vectors
* SHA3: `https://csrc.nist.gov/Projects/cryptographic-algorithm-validation-program/Secure-Hashing`
* Keccak origin: `https://keccak.team/archives.html` Known-answer and Monte Carlo test results part
* Blake2b: `https://github.com/jedisct1/crypto-test-vectors` and `https://pynacl.readthedocs.io/en/latest/vectors/blake2_vectors/`
* MD5/SHA2: `https://cryptii.com`
* HASH160: `https://bitcoinprices.org/public-key-to-hash/`
* RIPEMD160: `https://www.browserling.com/tools/ripemd160-hash`#### HMAC Test Vectors
* HMAC_SHA256/SHA512: `https://cryptii.com`
#### Ed25519 Test Vectors
* `https://ed25519.cr.yp.to/python/sign.input`
#### Secp256k1 Test Vectors
* `https://github.com/btccom/secp256k1-go`
* `https://github.com/google/wycheproof/tree/master/testvectors`For wycheproof test vectors, We only test against ecdh vectors. For ecdsa tests, some cases might fail because that the Bitcoin-Secp256k1 seems more strict. See an example [here](https://github.com/bitcoin-core/secp256k1/issues/609). We don't have a good way to distinguish those cases [now](https://github.com/google/wycheproof/issues/70).