To use:
import "github.com/IBM-Bluemix/golang-openssl-wrapper/crypto" // For encryption, e.g. EVP
import "github.com/IBM-Bluemix/golang-openssl-wrapper/ssl" // TLS
import "github.com/IBM-Bluemix/golang-openssl-wrapper/rand" // PRNG
import "github.com/IBM-Bluemix/golang-openssl-wrapper/digest" // Message-digest (hash) functions
import "github.com/IBM-Bluemix/golang-openssl-wrapper/bio" // OpenSSL-specific I/O handling
This library is being actively developed. It provides access to much of the OpenSSL APIs for cryptography (libcrypto) and TLS (libssl). We do not plan to provide the complete API at first, but if there is a function you need, please open an issue or submit a PR. The wrapper is built on swig
, so you will need to work directly with the .swig
files to add functionality.
If you submit a pull request, please be sure to include complete unit test coverage (we use ginkgo
and gomega
, which sit on top of golang's native testing facility), or your PR will be declined.
It based on the OpenSSL library and requires it to be installed with the FIPS module.
- Download FIPS module (openssl-fips-2.0.16.tar.gz) from here
- Unzip
- Run from folder
- Unordered sub-list.
- ./config (may require to specify folder and compiler. For me worked following line: ./Configure darwin64-x86_64-cc --prefix=/usr/local/opt --openssldir=/usr/local/opt/openssl)
- make
- sudo make install
- Download FIPS capable OpenSSL of version 1.0.2 (openssl-1.0.2t.tar.gz) from same link above
- Unzip
- Run from folder
- ./config (may require to specify folder and compiler. For me worked following line: ./Configure darwin64-x86_64-cc --prefix=/usr/local/opt --openssldir=/usr/local/opt/openssl)
- make
- make depend (only if being asked)
- make test (make sure all tests passed)
- sudo make install
Their help can be useful also, although it’s a one big mess