The rampart-crypto module¶
Preface¶
Acknowledgment¶
The rampart-crypto module uses the OpenSSL library. We extend our thanks to the developers for this indispensable tool.
License¶
The rampart-crypto module is released under the MIT license. The OpenSSL library is released under the OpenSSL License.
What does it do?¶
The rampart-crypto module provides methods to encrypt, decrypt, hash and generate HMACs from within Rampart JavaScript. It also includes the full libssl and libcrypto libraries and is needed for the rampart-curl and rampart-server modules to operate using the https protocol.
How does it work?¶
After the module is loaded, functions are provided to perform crypto operations on JavaScript Strings or Buffers.
Loading and Using the Module¶
Loading¶
Loading the module is a simple matter of using the require()
function:
var crypto = require("rampart-crypto");
Encryption and Decryption¶
encrypt¶
The encrypt()
function encrypts the contents of a String or Buffer. Encryption can be done by providing a key/iv pair or by providing a
password.
Usage:
var crypto = require("rampart-crypto");
var ciphertext = crypto.encrypt(options);
/* or */
var ciphertext = crypto.encrypt(pass, data[, cipher_mode]);
Where:
-
pass
is a password used to encrypt the data. -
data
is a String or Buffer, the data to be encrypted. -
cipher_mode
is one of the Supported Modes listed below. If not specified, the default isaes-256-cbc
. -
options
is an Object which may contain the following:-
data
- same asdata
above. -
cipher
- same ascipher_mode
above. -
pass
- a password used to generate a key/iv pair and encrypt the data. -
key
- required if not using a password - a key of the appropriate length for the chosen cipher.key
can be a Buffer or a hex encoded String. -
iv
- required if not using a password - an initialization vector of the appropriate length to be used for encrypting the data.iv
can be a Buffer or a hex encoded String. -
iter
- number of iterations for generating a key and iv frompass
. Default is10000
. If provided, the same value must be passed to decrypt below in order to decrypt the ciphertext.
-
- Return Value:
-
A Buffer containing the ciphertext (encrypted data). Using
crypto.encrypt("password", data)
produces the same results asopenssl enc -aes-256-cbc -e -pbkdf2 -pass pass:"password" -in myfile.txt
using openssl version 1.1.1 from the command line.
Example:
var crypto = require("rampart-crypto");
var ciphertext = crypto.encrypt("mypass", "my data", "aes-128-cbc");
- Caveat:
-
The choice of
10000
iterations is the default used by both the command lineopenssl
tool and rampart-crypto. It is purposefully slow, in order to make dictionary attacks on the password difficult. If computational speed is a factor (e.g. in a HTTP server context), choosing a password of random characters and significantly lowering theiter
value (or using thekey
andiv
options instead of a password) will be more performant.
decrypt¶
The decrypt()
function takes the same arguments as encrypt
above, but decrypts the data.
- Return Value:
-
A Buffer containing the decrypted text. Calling
crypto.decrypt("password", data)
produces the same results asopenssl enc -aes-256-cbc -d -pbkdf2 -pass pass:"password" -in myfile.enc
using openssl version 1.1.1 from the command line.
Example:
var crypto = require("rampart-crypto");
var ciphertext = crypto.encrypt({
pass: "mypass",
data: "my data"
});
var plaintext = crypto.decrypt({
pass: "mypass",
data: ciphertext
});
rampart.utils.printf('The decrypted data: "%s"\n', plaintext);
/* expected output:
The decrypted data: "my data"
*/
passToKeyIv¶
The passToKeyIv()
function performs the same password to key/iv pair generation as encrypt above.
Usage:
var crypto = require("rampart-crypto");
var kiv = crypto.passToKeyIv(options);
Where
-
options
is an Object which may contain the following:-
cipher
is a String and is one of the Supported Modes listed below. If not specified, the default isaes-256-cbc
. This option controls the key and iv length. -
pass
is a String, the password used to generate a key/iv pair. -
salt
is a String or Buffer, the optional salt for generation of the key and iv. If not provided, a random salt will be generated. If provided as a String it must be a hex encoded string representing at least 8 bytes. If provided as a Buffer, it must be at least 8 bytes in length. If longer than 8 bytes, only the first 8 bytes will be used. -
iter
- number of iterations for generating a key and iv frompass
. Default is10000
. -
returnBuffer
is an Boolean, iftrue
the key, iv and salt will be returned as binary data in Buffers. Otherwise if not set orfalse
, they will be encoded as a hex Strings.
-
- Return Value:
-
An Object containing the key, iv and salt as hex encoded
Strings or as binary data in Buffers.
The function
crypto.passToKeyIv
produces the same results asopenssl enc -<cipher_mode> -pbkdf2 -k <password> [-S <salt_as_hex>] -P
using openssl version 1.1.1 from the command line.
Example:
var crypto = require("rampart-crypto");
var salt = crypto.sha1("a unique string for one time use as salt");
var kiv = crypto.passToKeyIv({
pass: "mypass",
salt: salt
});
var ciphertext = crypto.encrypt({
key: kiv.key,
iv: kiv.iv,
data: "my data"
});
/*
note that when key/iv is used in encrypt instead of a password, salt
is not stored in the ciphertext, and the ciphertext must be decrypted
with the same key, iv derived using both 'password' and 'salt'.
*/
var plaintext = crypto.decrypt({
key: kiv.key,
iv: kiv.iv,
data: ciphertext
});
rampart.utils.printf('Key/Iv/Salt: "%3J"\n\n', kiv);
rampart.utils.printf('The decrypted data: "%s"\n', plaintext);
/* expected output:
Key/Iv/Salt: "{
"key": "215a744a875c4604046f05a34164507cf9f8c54342f75b1d58ad5d1f428aadd2",
"iv": "daffcd9ff10128eee4f19375f1aa4dde",
"salt": "ce37ddf6cda911f4"
}"
The decrypted data: "my data"
*/
Supported Modes¶
The following cipher/modes are supported in rampart:
mode name | Description |
---|---|
bf-cbc | Blowfish in CBC mode |
bf-cfb | Blowfish in CFB mode |
bf-ecb | Blowfish in ECB mode |
bf-ofb | Blowfish in OFB mode |
cast-cbc | CAST in CBC mode |
cast5-cbc | CAST5 in CBC mode |
cast5-cfb | CAST5 in CFB mode |
cast5-ecb | CAST5 in ECB mode |
cast5-ofb | CAST5 in OFB mode |
des-cbc | DES in CBC mode |
des-cfb | DES in CBC mode |
des-ofb | DES in OFB mode |
des-ecb | DES in ECB mode |
des-ede-cbc | Two key triple DES EDE in CBC mode |
des-ede | Two key triple DES EDE in ECB mode |
des-ede-cfb | Two key triple DES EDE in CFB mode |
des-ede-ofb | Two key triple DES EDE in OFB mode |
des-ede3-cbc | Three key triple DES EDE in CBC mode |
des-ede3 | Three key triple DES EDE in ECB mode |
des-ede3-cfb | Three key triple DES EDE CFB mode |
des-ede3-ofb | Three key triple DES EDE in OFB mode |
desx | DESX algorithm. |
idea-cbc | IDEA algorithm in CBC mode |
idea-cfb | IDEA in CFB mode |
idea-ecb | IDEA in ECB mode |
idea-ofb | IDEA in OFB mode |
rc2-cbc | 128 bit RC2 in CBC mode |
rc2-cfb | 128 bit RC2 in CFB mode |
rc2-ecb | 128 bit RC2 in ECB mode |
rc2-ofb | 128 bit RC2 in OFB mode |
rc2-64-cbc | 64 bit RC2 in CBC mode |
rc2-40-cbc | 40 bit RC2 in CBC mode |
rc4 | 128 bit RC4 |
rc4-40 | 40 bit RC4 |
aes-256-cbc | 256 bit AES in CBC mode |
aes-256-cfb | 256 bit AES in 128 bit CFB mode |
aes-256-cfb1 | 256 bit AES in 1 bit CFB mode |
aes-256-cfb8 | 256 bit AES in 8 bit CFB mode |
aes-256-ecb | 256 bit AES in ECB mode |
aes-256-ofb | 256 bit AES in OFB mode |
aes-192-cbc | 192 bit AES in CBC mode |
aes-192-cfb | 192 bit AES in 128 bit CFB mode |
aes-192-cfb1 | 192 bit AES in 1 bit CFB mode |
aes-192-cfb8 | 192 bit AES in 8 bit CFB mode |
aes-192-ecb | 192 bit AES in ECB mode |
aes-192-ofb | 192 bit AES in OFB mode |
aes-128-cbc | 128 bit AES in CBC mode |
aes-128-cfb | 128 bit AES in 128 bit CFB mode |
aes-128-cfb1 | 128 bit AES in 1 bit CFB mode |
aes-128-cfb8 | 128 bit AES in 8 bit CFB mode |
aes-128-ecb | 128 bit AES in ECB mode |
aes-128-ofb | 128 bit AES in OFB mode |
RSA Encryption¶
rsa_gen_key¶
Generate an RSA key pair.
Usage:
var crypto = require("rampart-crypto");
var key = crypto.rsa_gen_key([bits][, password]);
Where:
bits
is a Number such as1024
,2048
4096
or8192
. The number of modulus bits. Default is4096
if not specified.password
is an optional String, a password to encrypt the private key.
- Return Value:
-
An Object with the following properties:
-
public
- the public key in pkcs8pem
format. -
private
- the private key in pkcs8pem
format, encrypted ifpassword
is given. -
rsa_public
- the public key in pkcs1 rsa public keypem
format. -
rsa_private
- the private key in pkcs1 rsa private keypem
format, encrypted ifpassword
is given.
-
Example:
var crypto = require("rampart-crypto");
/* for demo - generally should be 2048 or greater */
var key = crypto.rsa_gen_key(1024, "mypass");
rampart.utils.printf( "%s\n%s\n%s\n%s\n",
key.private,
key.public,
key.rsa_private,
key.rsa_public
);
/* expect output similar to the following:
-----BEGIN ENCRYPTED PRIVATE KEY-----
MIIC3TBXBgkqhkiG9w0BBQ0wSjApBgkqhkiG9w0BBQwwHAQI5x3aqPg9MqgCAggA
MAwGCCqGSIb3DQIJBQAwHQYJYIZIAWUDBAEqBBAoAyT6LBBnFh3Hd7HhQp+XBIIC
gHv1acYJPZeNkeTIVX2531fJXmRhWYC1CA6T6eb6fSTLo7ZEnX1kYA34kyhyhj0R
MOi1mkCZSkdsf8Z/emRCHycWcuJqtAscwpBfURHcTKTzOb2MwQ8hnNLc4lmLOwD2
Vp6TwqO1JRrR+xeoLuTas+vfzklaRX1c4zSfAU9S2GXdXHJbCtvnFY5HrpMnm0bb
5d9q0SuMXUFVQM5R5EcXwu7mwuVQbNFK1LZEggzBjdueq5mF3MDvLwaDvoOIffz1
dPKoj4YPwCFT/RCUhBFz16uHXKK2glPYVYQ2/LYpJK9+hKvWYLWg5veqNyu5TMjb
crLKvgKE0k/5eJb89hWkOTn00+pcP3b0jAF/iSSwbOokW0H7gZChjRy2CFuJf+t6
Gx0kndn2hV1722XDaPj+L3tQrjmatSdYEUPMLYfY8NED54GbXndBRY27zJ8ulSjS
GbMW6iwB2jdO5kKkZrjechLt3pJOC4W6BKlrZXESnZO9TIy1/erwMg3ppId0RtKT
HgC7b8q8Vw/+9rwi3ksyqWcsEC+CCOaCTjfr6JOiDG1EFQ+wBH4ysoojjo3AQGjY
mve01KNEBD14+SdLO1Tm6wJfHarUDV0EliSr9cXHHUTZPkFLa4n06C31GfD1McJM
ky9gSK59qP6n55YDEokVeT6Ei7Q+tgBftg+HisP5QUU2pzlmE5kBfb8lSizUW/Pj
uBoEVedCxAHQ3Yl3TrMv5URNkFhb3Prsb5YTm7lczEsmk80NAF+obl7iqii4X4Wn
E2QYpF370fhUmjYsA2G0xugYI+uOf6DepUUEan20SsLRWQk5cqrIFnJlNbnKzaRt
FaY/wG/NAIHOVONb87bu1Z4=
-----END ENCRYPTED PRIVATE KEY-----
-----BEGIN PUBLIC KEY-----
MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQC7lkrZ6gREJZT6ZWjvFxrm+lPY
dyE1uplaTbV87AirYHfQRTef3y87B/yL/Qud3brcPUePryqNz20wxZk8hDe0PAHC
IcM1c3STPxAvo+YJXbjt6DmoC+UK9nkIKXLg1lR9VMVYr9Gri8KWmyXAxHdmTSpf
njNlXdlur240f9negQIDAQAB
-----END PUBLIC KEY-----
-----BEGIN RSA PRIVATE KEY-----
Proc-Type: 4,ENCRYPTED
DEK-Info: AES-256-CBC,19216181CEB7C4E59C2D9B8F1F8E4323
E+1namuNDSCDzRU2O5tq5t78zQ4EobMVNLXzy0yjA9IN1zW6IMxH5WE7wZ48/FZl
uRFokQrr1xMJB667U0ZtSMS0Ol3q1DZAZvOakpXV21LtKgVEO/E3XM+la5+O+hJ3
Nhzb58gJKnC3GfexxlxrLeFx+rXwtYNY0wZqAy9yo+QNHEE7JZgYqHipIfxhKlqx
hmYA5c3ztd7+j2aEq4boRWQdqL5GBzjhAOKYi7goic3SU/kQQmsu7bA7q4KqVn8P
l0aygNweimO9xkFuZrngdtVeZ/8nA6TsNVJOyI6NanA/iV7SuGYXczqP198P62m7
2sJkHGJwiR0X6tb95+0sjEofujbRv/6eFV1Tv8r42zEXkESet1XMjxOoEwBLWLbH
+5RThxkGLfAWDsssq6bo9ilgw2qI0xW9CEtcBmkn574+j0ScIk/2J69cyiIdJNZn
WNtC0mzKGHMEn+xpYsszyUbS7EgAg3LrV0irl2Kbjm3xTgtKhRXXC7lqbrBoAJF4
gwwfusEF9jNMoWBkl15oIuUK2/PIgd4IRVBDGX76pcjoTIeTRqulsXuxcl6GKHm9
KskhZBP08MlN7j4cXc7GmmO4MnzghHNUeqs3Aok2JV4ulimL/7IiaJFQvh01WVk+
hrQUPnjRVnSzHejBNFqCFCr9XKh72NbTr/6qvzJg8pIjNemb2Vo4rrc2ITzHcS/g
O88JtrnZjroB37Av6ELTrqJ/G02pdVs8i8FEb/Vnvd6MsTaSwSHJEAFMP6LqhPI0
ukVkqYB7E1HL0iWS3mgC7eLmWfrx6i0XSMQoWJFNKJAzOlo8K2+McluDl7x/3Cfz
-----END RSA PRIVATE KEY-----
-----BEGIN RSA PUBLIC KEY-----
MIGJAoGBALuWStnqBEQllPplaO8XGub6U9h3ITW6mVpNtXzsCKtgd9BFN5/fLzsH
/Iv9C53dutw9R4+vKo3PbTDFmTyEN7Q8AcIhwzVzdJM/EC+j5glduO3oOagL5Qr2
eQgpcuDWVH1UxViv0auLwpabJcDEd2ZNKl+eM2Vd2W6vbjR/2d6BAgMBAAE=
-----END RSA PUBLIC KEY-----
*/
rsa_import_priv_key¶
Import an existing private key and generate a new public and private keys.
Usage:
var crypto = require("rampart-crypto");
var key = crypto.rsa_import_priv_key(oldprivate_key[, opts]);
/* or */
var key = crypto.rsa_import_priv_key(oldprivate_key[, oldpass][, newpass]);
Where:
oldprivate_key
is an Object or String, the pem formatted private key.opts
is an Object with the properties{decryptPassword: "oldpass", encryptPassword: "newpass"}
.oldpass
is a String, the password to decryptoldprivate_key
, if encrypted.newpass
is a String, an optional password to encrypt the return private keys.
- Return Value:
-
An Object with the following properties:
-
public
- the public key in pkcs8pem
format. -
private
- the private key in pkcs8pem
format, encrypted ifnewpass
is given. -
rsa_public
- the public key in pkcs1 rsa public keypem
format. -
rsa_private
- the private key in pkcs1 rsa private keypem
format, encrypted ifnewpass
is given.
-
rsa_components¶
Get the component parts of an RSA public or private key.
Usage:
var crypto = require("rampart-crypto");
var components = crypto.rsa_components(key);
- Return Value:
-
An Object.
If
key
is a public key, the following properties are set:-
exponent
- a String with the hex encoded value of the exponent. -
modulus
- a String with the hex encoded value of the modulus.
If
key
is a private key, in addition to the above:-
privateExponent
- a String with the hex encoded value of the private exponent. -
privateFactorq
- a String with the hex encoded value of the private factorq
. -
privateFactorp
- a String with the hex encoded value of the private factorp
.
-
rsa_pub_encrypt¶
Encrypt data using an RSA public key. The public key can be in either pem format generated by rsa_gen_key().
Usage:
var crypto = require("rampart-crypto");
var res = crypto.rsa_pub_encrypt(data, public_key[, paddingMode]);
Where:
data
is a String or Buffer with the content to encrypt.
public_key
is a String or Buffer with the content of the public key.
paddingMode
is an optiona String that is one of the following (as described here):
"pkcs"
- default if not specified. Use PKCS #1 v1.5 padding. This currently is the most widely used mode."oaep"
- Use EME-OAEP as defined in PKCS #1 v2.0 with SHA-1, MGF1 and an empty encoding parameter. This mode is recommended for all new applications."ssl"
- PKCS #1 v1.5 padding with an SSL-specific modification that denotes that the server is SSL3 capable."raw"
- Raw RSA encryption. This mode should only be used to implement cryptographically sound padding modes in the application code. Encrypting user data directly with RSA is insecure.Note that Openssl Library includes this warning:
“Decryption failures in the RSA_PKCS1_PADDING mode leak information which can potentially be used to mount a Bleichenbacher padding oracle attack. This is an inherent weakness in the PKCS #1 v1.5 padding design. Prefer RSA_PKCS1_OAEP_PADDING.” - see this document.
Note also that the length of
data
cannot be more than the number of bytes of the modulus used to create the key pair minus 11 (or minus 42 in the case of"oaep"
, or minus 0 in the case ofraw
).
- Return Value:
- A Buffer containing the encrypted text.
Example:
var crypto = require("rampart-crypto");
var data = ""
var str = "contents of my potentially long data file...\n";
/* make content longer than can fit in rsa encrypted text */
for (i=0; i<100; i++)
data+=str;
/* seed the random number generator before use */
crypto.seed();
/* generate random data and base64 encode for easy use*/
var symmetric_passwd = rampart.utils.sprintf("%B", crypto.rand(48));
/* encrypt data using the random base64 data as the password */
var ciphertext = crypto.encrypt(symmetric_passwd, data);
/* rsa encrypt the password with public key */
var encrypted_passwd = crypto.rsa_pub_encrypt(
symmetric_passwd,
rampart.utils.readFile("pubkey.pem")
);
/* transmit ciphertext and encrypted password to
owner of the corresponding private key */
rsa_priv_decrypt¶
Decrypt encrypted data using an RSA private key. The private key can be in either pem format generated by rsa_gen_key().
Usage:
var crypto = require("rampart-crypto");
var res = crypto.rsa_priv_decrypt(data, private_key[, paddingMode][, password]);
Where:
data
is a String or Buffer with the content to decrypt.private_key
is a String or Buffer with the contents of the private key.paddingMode
- a String. See above - the same padding mode used to encrypt the data.password
- a String, ifprivate_key
is password protected, the password used to encrypt the private key.
- Return Value:
- A Buffer containing the decrypted text.
Example:
/* continuing example from above, owner of privatekey.pem can do this */
var crypto = require("rampart-crypto");
/* receive ciphertext and encrypted password from above */
symmetric_passwd = crypto.rsa_priv_decrypt(
encrypted_passwd,
rampart.utils.readFile("privatekey.pem"),
null, /* use default "pkcs" */
"mysecretpassword"
);
/* decrypt message
password must be a string */
var plaintext = crypto.decrypt(
rampart.utils.bufferToString(symmetric_passwd),
ciphertext
);
rampart.utils.printf("%s", plaintext);
/* expected output:
contents of my potentially long data file...
contents of my potentially long data file...
...
contents of my potentially long data file...
*/
rsa_sign¶
Sign a message with an RSA private key. The private key can be in either pem format generated by rsa_gen_key().
Usage:
var crypto = require("rampart-crypto");
var signature = crypto.rsa_sign(message, private_key[, password]);
Where:
message
is a String or Buffer with the content to sign.private_key
is a String or Buffer with the contents of the private key.password
- a String, ifprivate_key
is password protected, the password used to encrypt the private key.
- Return Value:
-
A Buffer with the content of the signature. Same as
openssl dgst -sha256 -sign private_key.pem -out sig msg.txt
rsa_verify¶
Verify a signed message with an RSA public key. The public key can be in either pem format generated by rsa_gen_key().
Usage:
var crypto = require("rampart-crypto");
var verified = crypto.rsa_verify(data, public_key, signature);
Where:
data
is a String or Buffer with the content to verify.public_key
is a String or Buffer with the contents of the public key.signature
- a Buffer containing the signature generated withrsa_sign
above, or with openssl.
- Return Value:
-
A Boolean -
true
if verification succeeded. Otherwisefalse
. Same asopenssl dgst -sha256 -verify public_key.pem -signature sig msg.txt
.
gen_csr¶
Generate a certificate signing request.
Usage:
var crypto = require("rampart-crypto");
var csr = crypto.gen_csr(private_key, opts[, password]);
Where:
private_key
is a String, a pem formatted private key.
opts
is an Object, with the following optional property Strings:
name
- The “Common Name”, usually the relevant domain name.country
- A two letter country code (i.e.US
orDE
).state
- State or Province name.city
- The locality or city of your organization.organization
- The full legal name of your organization.organizationUnit
- The department of your organization.subjectAltName
- text to be placed in theAttributes
->Requested Extensions
->X509v3 Subject Alternative Name
section of the certificate request. Also accepts an Array of Strings for multiple values.subjectAltNameType
- The type used for values insubjectAltName
. If, e.g.,dns
is set andsubjectAltName
is set to["example.com", "www.example.com"]
, the certificate signing request will include theX509v3 Subject Alternative Name
value ofDNS:example.com, DNS:www.example.com
. Possible values aredns
(the default if not specified),ip
,uri
,x400
,dirname
,rid
orothername
(case insensitive). See openssl documentation for meaning and usage of each. For requesting an SSL/TLS certificate for a webserver,dns
should be used, particularly where the requested certificate will cover more than one domain name.
password
- ifprivate_key
is password protected, the password to decrypt the private key.
- Return Value:
-
A Object with the following properties:
-
pem
- A String - the generated certificate signing request in pem format. -
der
- A Buffer - the generated certificate signing request in der binary format.
-
Example:
var crypto = require("rampart-crypto");
/* generate a server key */
var key = crypto.rsa_gen_key(4096 /* ,"password" */);
/* save it for use with webserver */
rampart.utils.fprintf("./server.key", '%s', key.private);
/* generate a signing request for current domains */
var csr = crypto.gen_csr(
key.private,
{
name: "example.com",
subjectAltName: ["example.com", "www.example.com"]
}
/* , "password" */
);
/* csr == {pem: pem_formatted_csr, der: der_formatted_csr} */
Password¶
passwd¶
Compute a salt/password entry using a standard algorithm.
Usage:
var crypto = require("rampart-crypto");
var pwentry = crypto.passwd(pass[, salt[, algo]]);
Where
pass
is a String, the password to be hashed.salt
is a String, the salt to use to create the hash, ornull
to generate a salt.algo
is a String, one ofsha512
(default),sha256
,md5
,apr1
,aixmd5
, orcrypt
.
- Return Value:
-
An Object with keys
line
,salt
,hash
andmode
.
See example below in passwdCheck.
passwdComponents¶
Given a hash entry from a file such as /etc/passwd
or /etc/shadow
, return the components.
Usage:
var crypto = require("rampart-crypto");
var components = crypto.passwdComponents(line);
- Return Value:
- Same as passwd above.
passwdCheck¶
Given a hash entry and a password, check if they match.
Usage:
var crypto = require("rampart-crypto");
var passok = crypto.passwdCheck(line, passwd);
Where:
line
is a String, theline
property from the return of passwd or a hash entry from a file such as/etc/passwd
or/etc/shadow
.passwd
is a String, the password to check.
- Return Value:
-
a Boolean,
true
if the password matches the hash. Otherwisefalse
.
Example:
var crypto = require("rampart-crypto");
var pw = crypto.passwd("mypasswd", null, "md5");
rampart.utils.printf("%3J\n", pw);
/* Sample Output:
{
"line": "$1$YR/UxoNq$cSEfWsMQH5OC7xY/AYM8S1",
"salt": "YR/UxoNq",
"hash": "cSEfWsMQH5OC7xY/AYM8S1",
"mode": "md5"
}
*/
var line="$1$epCdp7c5$QROtiBBauvN/HPi5e22ty1";
var components = crypto.passwdComponents(line);
rampart.utils.printf("%3J\n", components);
/* Expected Output:
{
"line": "$1$epCdp7c5$QROtiBBauvN/HPi5e22ty1",
"salt": "epCdp7c5",
"hash": "QROtiBBauvN/HPi5e22ty1",
"mode": "md5"
}
*/
if(crypto.passwdCheck(line, "mypasswd"))
console.log("password ok");
else
console.log("password fail");
/* Expected Output:
password ok
*/
Hashing¶
hash¶
The hash()
function
calculates a hash of the data in a String or Buffer and returns it in a hex encoded String or as
binary data in a Buffer.
Usage:
var crypto = require("rampart-crypto");
var res = hash(data[, hash_func][, return_buffer]);
Where:
-
data
is a String or Buffer, the data to be hashed. -
hash_func
is an optional String, one of the following:sha1
,sha224
,sha256
,sha384
,sha512
,md4
,md5
,sha3-224
,sha3-256
,sha3-384
,sha3-512
,blake2b512
,blake2s256
,mdc2
,rmd160
,sha512-224
,sha512-256
,shake128
,shake256
,sm3
. Default issha256
. -
return_buffer is a Boolean, if
true
, the output will be binary data in a Buffer, and not hex encoded.
- Return Value:
- A String or Buffer, the hash of the data.
Example:
var crypto = require("rampart-crypto");
var res = crypto.hash("hello world", "sha256");
/*
res == 'b94d27b9934d3e08a52e52d7da7dabfac484efe37a5380ee9088f7ace2efcde9'
*/
alias functions¶
The hash function has an alias for each of the possible hash_func
value above. Thus,
using crypto.hash("hello
world", "sha256")
is equivalent to
crypto.sha256("hello
world")
. For hash_func
names with a dash
(-
), an underscore
(_
) is used instead.
Thus crypto.hash("hello
world", "sha3-256")
is equivalent to
crypto.sha3_256("hello
world")
.
hmac¶
The hmac()
function
computes a HMAC from the provided data and key.
Usage:
var crypto = require("rampart-crypto");
var res = crypto.hmac(secret, data[, hash_func][, return_buffer]);
Where:
secret
is the HMAC function key.
data
is a String or Buffer, the data to be hashed.
hash_func
is an optional String, one of the following:
sha1
,sha224
,sha256
,sha384
,sha512
,md4
,md5
,sha3-224
,sha3-256
,sha3-384
,sha3-512
,blake2b512
,blake2s256
,mdc2
,rmd160
,sha512-224
,sha512-256
,sm3
. Default issha256
.return_buffer is a Boolean, if
true
, the output will be binary data in a Buffer, and not hex encoded.
- Return Value:
- A String or Buffer, the hmac hash of the data.
Random¶
rand¶
The rand()
function
returns random generated bytes in a buffer.
Usage:
var crypto = require("rampart-crypto");
var res = crypto.rand(nBytes);
Where nBytes
is the
number of bytes to return.
- Return Value:
-
a Buffer with
nBytes
bytes of random data.
randnum¶
The randnum()
function returns a random Number between 0.0
and 1.0
.
gaussrand¶
The gaussrand([sigma])
function returns a random Number based on a normal distribution centered at zero (0.0
), where sigma
is one standard deviation.
sigma
is optional,
defaulting to 1.0
.
normrand¶
The normrand([scale])
function returns a random Number based on a normal distribution centered at zero (0.0
) and clamped between
-scale
and
scale
.
Similar to the gaussrand above. It is equivelant to:
var nrand = scale * crypto.gaussrand(1.0)/5.0;
if(nrand>scale)
nrand=scale;
else if (nrand < -scale)
nrand = -scale;
With a scale
of
1.0
(the default),
the distribution of numbers has a standard deviation of 0.2
.
seed¶
The seed()
function
seeds the random number generator from a file. There is no return value.
Usage:
var crypto = require("rampart-crypto");
var res = crypto.seed([options]);
Where options is an Object, if provided, and contains the following properties:
-
file
- a String - location of the file. Default is/dev/urandom
. -
bytes
- a Number - Number of bytes to retrieve fromfile
. Default is32
.
BigInt¶
The rampart-crypto module includes functions which handle arbitrarily long integers using
openssl’s BIGNUM
library. It is designed to be compatible with the JSBI library and includes the same published
functions. See JSBI Node
Module for more information.
Usage as documented below is as such:
var crypto = require("rampart-crypto");
var JSBI = crypto.JSBI;
JSBI.BigInt¶
Create a BigInt from a String or Number.
Possible Strings:
-
1234
-
-1234
-
0x123e
-
-0x123e
-
-0b11110011
-
-0b11110011
Example:
var crypto = require("rampart-crypto");
var JSBI = crypto.JSBI;
var mybignum = JSBI.BigInt("123456789012345678901234567890");
JSBI Compatible functions¶
JSBI functions aspire to operate in a manner that mirrors the JSBI library. Please see that library for details. Available commands include:
JSBI.BigInt(num).toString()
, JSBI.toNumber()
, JSBI.asIntN()
, JSBI.asUintN()
, a instanceof
JSBI
, JSBI.add()
, JSBI.subtract()
, JSBI.multiply()
, JSBI.divide()
, JSBI.remainder()
, JSBI.exponentiate()
, JSBI.unaryMinus()
, JSBI.bitwiseNot()
, JSBI.leftShift()
, JSBI.signedRightShift()
,
JSBI.bitwiseAnd()
,
JSBI.bitwiseOr()
,
JSBI.bitwiseXor()
,
JSBI.equal()
,
JSBI.notEqual()
,
JSBI.lessThan()
,
JSBI.lessThanOrEqual()
, JSBI.greaterThan()
, JSBI.greaterThanOrEqual()
,
JSBI.EQ()
,
JSBI.NE()
,
JSBI.LT()
,
JSBI.LE()
,
JSBI.GT()
,
JSBI.GE()
,
JSBI.ADD()
.
Note that in rampart, JSBI.BigInt().toString()
only accepts 2
, 10
and 16
as possible arguments, with
10
being the
default.
toSignedString¶
JSBI.BigInt().toSignedString()
will convert a BigInt into a string
representing the equivalent signed number. This differs from JSBI.BigInt().toString()
only
when used for a signed binary integer (using JSBI.BigInt(num).toSignedString(2)
).
Example:
var crypto = require("rampart-crypto");
var JSBI = crypto.JSBI;
var mybignum = JSBI.BigInt("-256");
console.log( mybignum.toString(2) );
console.log( mybignum.toSignedString(2) );
/* expected output:
-100000000
1111111100000000
*/