2020-12-21 11:45:07 +00:00
# bearssl
[data:image/s3,"s3://crabby-images/05888/058885bef8d1ec672e66a29a2266a8f7bac18fb7" alt="Build Status (Travis) "")](https://travis-ci.org/status-im/nim-bearssl)
[data:image/s3,"s3://crabby-images/2c42f/2c42f7f0c5e7aa9d04bed83b3a16cc31356dfb13" alt="Windows build status (Appveyor) "")](https://ci.appveyor.com/project/nimbus/nim-bearssl)
data:image/s3,"s3://crabby-images/05ec7/05ec76b74ed613dfbc30c67f622716bcf4e01f5d" alt="Stability: experimental "
[data:image/s3,"s3://crabby-images/b1455/b1455f26652e09c18dbaaa3d95d217681d033c36" alt="License: MIT "](https://opensource.org/licenses/MIT)
[data:image/s3,"s3://crabby-images/a516d/a516d1278a26f2cbf35ca5f2fd190bc7ae77db2c" alt="License: Apache "](https://opensource.org/licenses/Apache-2.0)
2021-06-09 14:59:52 +00:00
data:image/s3,"s3://crabby-images/a0bbe/a0bbeeb4d236b2c9bfe02e52764b93544f06fe8c" alt="Github action "
2020-12-21 11:45:07 +00:00
2022-09-07 16:16:28 +00:00
Simple [BearSSL ](https://bearssl.org/ ) wrapper for Nim, fully integrated with the Nim build system.
Applications using `nim-bearssl` are fully stand-alone, needing no additional DLL or shared library.
## Usage
The library is organised into two parts:
* `bearssl/` (except for `abi` ) exposes thin wrappers around the raw ABI making the functions more convenient to use in Nim
* `bearssl/abi` exposes the raw C functions of bearssl
For each `bearssl` header file, a corresponding Nim file exists - `bearssl_rand.h` ~ `bearssl/rand.nim` .
```nim
# You can import the whole library
import bearssl
# ... or simply parts thereof, which can save compilation time
import bearssl/rand
```
In general, the mappings follow the conventions of the original BearSSL library closely. The following conventions exist:
* the `br_` prefix has been dropped throughout
* functions taking a `XxxContext*` use `var` and not `ptr`
* `byte` replaces `unsigned char*` - this type is predominantly used for byte buffers
* `uint` used instead of `csize_t` - these are the same type in Nim, but spelled more conveniently
* Canonical nim code will have to be careful when converting existing `int` lengths, looking out for out-of-range values
In addition to the raw `C` -like api, convenience functions are added where applicable - these follow a similar set of conventions:
* named after the function they simplify, but take advantage of types and overload support in Nim
* help turn pointers and bytes into Nim types
2020-12-21 11:45:07 +00:00
## Installation
2022-09-07 16:16:28 +00:00
You can install the developement version of the library through nimble with the following command:
2020-12-21 11:45:07 +00:00
```
nimble install bearssl
```
2022-09-07 16:16:28 +00:00
`BearSSL` itself is compiled as part of your project - there is no need to install any third-party libraries.
## Developer notes
When updating the library, `c2nim` is used via `regenerate.sh` to update the RAW ABI files. Manual editing is then needed to make a few adjustments to the mapping, after which the files can be generated.
When adding new convenience functions, these should be added to `bearssl/` instead of the generated files.
2020-12-21 11:45:07 +00:00
## License
Licensed and distributed under either of
* MIT license: [LICENSE-MIT ](LICENSE-MIT ) or http://opensource.org/licenses/MIT
or
* Apache License, Version 2.0, ([LICENSE-APACHEv2 ](LICENSE-APACHEv2 ) or http://www.apache.org/licenses/LICENSE-2.0)
at your option. This file may not be copied, modified, or distributed except according to those terms.