1 | 'use strict'
|
2 |
|
3 | exports.randomBytes = exports.rng = exports.pseudoRandomBytes = exports.prng = require('randombytes')
|
4 | exports.createHash = exports.Hash = require('create-hash')
|
5 | exports.createHmac = exports.Hmac = require('create-hmac')
|
6 |
|
7 | var algos = require('browserify-sign/algos')
|
8 | var algoKeys = Object.keys(algos)
|
9 | var hashes = ['sha1', 'sha224', 'sha256', 'sha384', 'sha512', 'md5', 'rmd160'].concat(algoKeys)
|
10 | exports.getHashes = function () {
|
11 | return hashes
|
12 | }
|
13 |
|
14 | var p = require('pbkdf2')
|
15 | exports.pbkdf2 = p.pbkdf2
|
16 | exports.pbkdf2Sync = p.pbkdf2Sync
|
17 |
|
18 | var aes = require('browserify-cipher')
|
19 |
|
20 | exports.Cipher = aes.Cipher
|
21 | exports.createCipher = aes.createCipher
|
22 | exports.Cipheriv = aes.Cipheriv
|
23 | exports.createCipheriv = aes.createCipheriv
|
24 | exports.Decipher = aes.Decipher
|
25 | exports.createDecipher = aes.createDecipher
|
26 | exports.Decipheriv = aes.Decipheriv
|
27 | exports.createDecipheriv = aes.createDecipheriv
|
28 | exports.getCiphers = aes.getCiphers
|
29 | exports.listCiphers = aes.listCiphers
|
30 |
|
31 | var dh = require('diffie-hellman')
|
32 |
|
33 | exports.DiffieHellmanGroup = dh.DiffieHellmanGroup
|
34 | exports.createDiffieHellmanGroup = dh.createDiffieHellmanGroup
|
35 | exports.getDiffieHellman = dh.getDiffieHellman
|
36 | exports.createDiffieHellman = dh.createDiffieHellman
|
37 | exports.DiffieHellman = dh.DiffieHellman
|
38 |
|
39 | var sign = require('browserify-sign')
|
40 |
|
41 | exports.createSign = sign.createSign
|
42 | exports.Sign = sign.Sign
|
43 | exports.createVerify = sign.createVerify
|
44 | exports.Verify = sign.Verify
|
45 |
|
46 | exports.createECDH = require('create-ecdh')
|
47 |
|
48 | var publicEncrypt = require('public-encrypt')
|
49 |
|
50 | exports.publicEncrypt = publicEncrypt.publicEncrypt
|
51 | exports.privateEncrypt = publicEncrypt.privateEncrypt
|
52 | exports.publicDecrypt = publicEncrypt.publicDecrypt
|
53 | exports.privateDecrypt = publicEncrypt.privateDecrypt
|
54 |
|
55 |
|
56 |
|
57 |
|
58 |
|
59 |
|
60 |
|
61 |
|
62 |
|
63 |
|
64 |
|
65 |
|
66 |
|
67 |
|
68 | var rf = require('randomfill')
|
69 |
|
70 | exports.randomFill = rf.randomFill
|
71 | exports.randomFillSync = rf.randomFillSync
|
72 |
|
73 | exports.createCredentials = function () {
|
74 | throw new Error([
|
75 | 'sorry, createCredentials is not implemented yet',
|
76 | 'we accept pull requests',
|
77 | 'https://github.com/crypto-browserify/crypto-browserify'
|
78 | ].join('\n'))
|
79 | }
|
80 |
|
81 | exports.constants = {
|
82 | 'DH_CHECK_P_NOT_SAFE_PRIME': 2,
|
83 | 'DH_CHECK_P_NOT_PRIME': 1,
|
84 | 'DH_UNABLE_TO_CHECK_GENERATOR': 4,
|
85 | 'DH_NOT_SUITABLE_GENERATOR': 8,
|
86 | 'NPN_ENABLED': 1,
|
87 | 'ALPN_ENABLED': 1,
|
88 | 'RSA_PKCS1_PADDING': 1,
|
89 | 'RSA_SSLV23_PADDING': 2,
|
90 | 'RSA_NO_PADDING': 3,
|
91 | 'RSA_PKCS1_OAEP_PADDING': 4,
|
92 | 'RSA_X931_PADDING': 5,
|
93 | 'RSA_PKCS1_PSS_PADDING': 6,
|
94 | 'POINT_CONVERSION_COMPRESSED': 2,
|
95 | 'POINT_CONVERSION_UNCOMPRESSED': 4,
|
96 | 'POINT_CONVERSION_HYBRID': 6
|
97 | }
|