https://github.com/sgiath/secp256k1
Elixir wrapper for Bitcoin Core secp256k1 library
https://github.com/sgiath/secp256k1
bitcoin cryptography elixir secp256k1
Last synced: 6 months ago
JSON representation
Elixir wrapper for Bitcoin Core secp256k1 library
- Host: GitHub
- URL: https://github.com/sgiath/secp256k1
- Owner: Sgiath
- License: other
- Created: 2023-01-16T10:25:00.000Z (almost 3 years ago)
- Default Branch: master
- Last Pushed: 2024-10-21T06:52:58.000Z (about 1 year ago)
- Last Synced: 2024-10-21T09:39:48.787Z (about 1 year ago)
- Topics: bitcoin, cryptography, elixir, secp256k1
- Language: Elixir
- Homepage: https://sgiath.dev/libraries#secp256k1
- Size: 105 KB
- Stars: 3
- Watchers: 3
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
# Secp256k1 library
[](https://hex.pm/packages/lib_secp256k1)
[](https://hexdocs.pm/lib_secp256k1)Elixir bindings for the [secp256k1](https://github.com/bitcoin-core/secp256k1) cryptographic
library, used extensively in blockchain and cryptocurrency applications.## Installation
Add `lib_secp256k1` to your project's dependencies in `mix.exs`:
```elixir
def deps do
[
{:lib_secp256k1, "~> 0.6.0"},
]
end
```The underlying C library and Elixir bindings are compiled automatically during the installation.
If you encounter issues during compilation, please check the original secp256k1 repository.Currently, compilation is tested primarily on Linux. If you experience issues on macOS or Windows,
please open an issue—although immediate support for these platforms is limited, contributions are
always welcome.### MacOS
You may need to install additional dependencies via Homebrew:
```
brew install make gcc autoconf autobuild
```## Features
- [x] generate secure random seckey
- [x] derive pubkey and serialize it in compressed, uncompressed or xonly format
- [x] generate and validate ECDSA signatures
- [x] generate and validate Schnorr signatures
- [x] compute Diffie-Hellman secret