1 |
|
2 |
|
3 |
|
4 |
|
5 |
|
6 |
|
7 |
|
8 |
|
9 |
|
10 |
|
11 |
|
12 |
|
13 |
|
14 |
|
15 |
|
16 |
|
17 |
|
18 |
|
19 |
|
20 |
|
21 |
|
22 |
|
23 |
|
24 |
|
25 |
|
26 |
|
27 |
|
28 |
|
29 |
|
30 |
|
31 |
|
32 |
|
33 |
|
34 | #ifndef _NODE_BLF_H_
|
35 | #define _NODE_BLF_H_
|
36 |
|
37 |
|
38 | #ifdef __sun
|
39 | #define u_int8_t uint8_t
|
40 | #define u_int16_t uint16_t
|
41 | #define u_int32_t uint32_t
|
42 | #define u_int64_t uint64_t
|
43 | #endif
|
44 |
|
45 | #ifdef _WIN32
|
46 | #define u_int8_t unsigned __int8
|
47 | #define u_int16_t unsigned __int16
|
48 | #define u_int32_t unsigned __int32
|
49 | #define u_int64_t unsigned __int64
|
50 | #endif
|
51 |
|
52 |
|
53 | #if defined(_WIN32) || defined(_WIN64)
|
54 | # if defined(_WIN64)
|
55 | typedef __int64 LONG_PTR;
|
56 | # else
|
57 | typedef long LONG_PTR;
|
58 | # endif
|
59 | typedef LONG_PTR SSIZE_T;
|
60 | typedef SSIZE_T ssize_t;
|
61 | #endif
|
62 |
|
63 | #define BCRYPT_VERSION '2'
|
64 | #define BCRYPT_MAXSALT 16
|
65 | #define BCRYPT_BLOCKS 6
|
66 | #define BCRYPT_MINROUNDS 16
|
67 |
|
68 |
|
69 |
|
70 |
|
71 |
|
72 |
|
73 |
|
74 |
|
75 | #define BLF_N 16
|
76 | #define BLF_MAXKEYLEN ((BLF_N-2)*4)
|
77 | #define BLF_MAXUTILIZED ((BLF_N+2)*4)
|
78 |
|
79 | #define _PASSWORD_LEN 128
|
80 | #define _SALT_LEN 32
|
81 |
|
82 |
|
83 | typedef struct BlowfishContext {
|
84 | u_int32_t S[4][256];
|
85 | u_int32_t P[BLF_N + 2];
|
86 | } blf_ctx;
|
87 |
|
88 |
|
89 |
|
90 |
|
91 |
|
92 |
|
93 |
|
94 | void Blowfish_encipher(blf_ctx *, u_int32_t *, u_int32_t *);
|
95 | void Blowfish_decipher(blf_ctx *, u_int32_t *, u_int32_t *);
|
96 | void Blowfish_initstate(blf_ctx *);
|
97 | void Blowfish_expand0state(blf_ctx *, const u_int8_t *, u_int16_t);
|
98 | void Blowfish_expandstate
|
99 | (blf_ctx *, const u_int8_t *, u_int16_t, const u_int8_t *, u_int16_t);
|
100 |
|
101 |
|
102 |
|
103 | void blf_key(blf_ctx *, const u_int8_t *, u_int16_t);
|
104 | void blf_enc(blf_ctx *, u_int32_t *, u_int16_t);
|
105 | void blf_dec(blf_ctx *, u_int32_t *, u_int16_t);
|
106 |
|
107 | void blf_ecb_encrypt(blf_ctx *, u_int8_t *, u_int32_t);
|
108 | void blf_ecb_decrypt(blf_ctx *, u_int8_t *, u_int32_t);
|
109 |
|
110 | void blf_cbc_encrypt(blf_ctx *, u_int8_t *, u_int8_t *, u_int32_t);
|
111 | void blf_cbc_decrypt(blf_ctx *, u_int8_t *, u_int8_t *, u_int32_t);
|
112 |
|
113 |
|
114 | u_int32_t Blowfish_stream2word(const u_int8_t *, u_int16_t , u_int16_t *);
|
115 |
|
116 |
|
117 | void bcrypt_gensalt(char, u_int8_t, u_int8_t*, char *);
|
118 | void bcrypt(const char *, const char *, char *);
|
119 | void encode_salt(char *, u_int8_t *, char, u_int16_t, u_int8_t);
|
120 | u_int32_t bcrypt_get_rounds(const char *);
|
121 |
|
122 | #endif
|