-
Notifications
You must be signed in to change notification settings - Fork 13
/
Copy pathphp_crypto_cipher.h
213 lines (181 loc) · 6.76 KB
/
php_crypto_cipher.h
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
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
/*
+----------------------------------------------------------------------+
| PHP Version 5 |
+----------------------------------------------------------------------+
| Copyright (c) 2013-2016 Jakub Zelenka |
+----------------------------------------------------------------------+
| This source file is subject to version 3.01 of the PHP license, |
| that is bundled with this package in the file LICENSE, and is |
| available through the world-wide-web at the following url: |
| http://www.php.net/license/3_01.txt |
| If you did not receive a copy of the PHP license and are unable to |
| obtain it through the world-wide-web, please send a note to |
| [email protected] so we can mail you a copy immediately. |
+----------------------------------------------------------------------+
| Author: Jakub Zelenka <[email protected]> |
+----------------------------------------------------------------------+
*/
#ifndef PHP_CRYPTO_CIPHER_H
#define PHP_CRYPTO_CIPHER_H
#include "php.h"
#include "php_crypto.h"
#include <openssl/evp.h>
typedef enum {
PHP_CRYPTO_CIPHER_STATUS_CLEAR,
PHP_CRYPTO_CIPHER_STATUS_ENCRYPT_INIT,
PHP_CRYPTO_CIPHER_STATUS_ENCRYPT_UPDATE,
PHP_CRYPTO_CIPHER_STATUS_ENCRYPT_FINAL,
PHP_CRYPTO_CIPHER_STATUS_DECRYPT_INIT,
PHP_CRYPTO_CIPHER_STATUS_DECRYPT_UPDATE,
PHP_CRYPTO_CIPHER_STATUS_DECRYPT_FINAL
} php_crypto_cipher_status;
PHPC_OBJ_STRUCT_BEGIN(crypto_cipher)
php_crypto_cipher_status status;
const EVP_CIPHER *alg;
EVP_CIPHER_CTX *cipher;
unsigned char *aad;
int aad_len;
unsigned char *tag;
int tag_len;
PHPC_OBJ_STRUCT_END()
/* Cipher status accessors */
#define PHP_CRYPTO_CIPHER_IS_IN_INIT_STATE(pobj) \
((pobj)->status == PHP_CRYPTO_CIPHER_STATUS_ENCRYPT_INIT || \
(pobj)->status == PHP_CRYPTO_CIPHER_STATUS_DECRYPT_INIT)
#define PHP_CRYPTO_CIPHER_IS_INITIALIZED_FOR_ENCRYPTION(pobj) \
((pobj)->status == PHP_CRYPTO_CIPHER_STATUS_ENCRYPT_INIT || \
(pobj)->status == PHP_CRYPTO_CIPHER_STATUS_ENCRYPT_UPDATE)
#define PHP_CRYPTO_CIPHER_IS_INITIALIZED_FOR_DECRYPTION(pobj) \
((pobj)->status == PHP_CRYPTO_CIPHER_STATUS_DECRYPT_INIT || \
(pobj)->status == PHP_CRYPTO_CIPHER_STATUS_DECRYPT_UPDATE)
#define PHP_CRYPTO_CIPHER_SET_STATUS(pobj, is_enc, status_name) \
(pobj)->status = ((is_enc) ? \
PHP_CRYPTO_CIPHER_STATUS_ENCRYPT_ ## status_name : \
PHP_CRYPTO_CIPHER_STATUS_DECRYPT_ ## status_name)
/* Algorithm object accessors */
#define PHP_CRYPTO_CIPHER_CTX(pobj) (pobj)->cipher
#define PHP_CRYPTO_CIPHER_ALG(pobj) (pobj)->alg
#define PHP_CRYPTO_CIPHER_AAD(pobj) (pobj)->aad
#define PHP_CRYPTO_CIPHER_AAD_LEN(pobj) (pobj)->aad_len
#define PHP_CRYPTO_CIPHER_TAG(pobj) (pobj)->tag
#define PHP_CRYPTO_CIPHER_TAG_LEN(pobj) (pobj)->tag_len
/* Exception */
PHP_CRYPTO_EXCEPTION_EXPORT(Cipher)
/* Error info */
PHP_CRYPTO_ERROR_INFO_EXPORT(Cipher)
/* Maximal algorithm length of the cipher algorithm name */
#define PHP_CRYPTO_CIPHER_ALGORITHM_LEN_MAX 1024
/* Mode string length */
#define PHP_CRYPTO_CIPHER_MODE_LEN 3
/* Cipher mode lookup table entry struct */
typedef struct {
const char name[PHP_CRYPTO_CIPHER_MODE_LEN+1];
const char constant[PHP_CRYPTO_CIPHER_MODE_LEN+6];
long value;
zend_bool auth_enc; /* authenticated encryption */
zend_bool auth_inlen_init;
int auth_ivlen_flag;
int auth_set_tag_flag;
int auth_get_tag_flag;
} php_crypto_cipher_mode;
/* Constant value for cipher mode that is not implemented
* (when using old version of OpenSSL) */
#define PHP_CRYPTO_CIPHER_MODE_NOT_DEFINED -1
/* Cipher mode value (EVP code) */
#define PHP_CRYPTO_CIPHER_MODE_VALUE(pobj) \
EVP_CIPHER_mode(PHP_CRYPTO_CIPHER_ALG(pobj))
/* Macros for cipher mode lookup table */
#define PHP_CRYPTO_CIPHER_MODE_ENTRY_EX( \
mode_name, \
mode_auth_enc, \
mode_auth_inlen_init, \
mode_auth_ivlen_flag, \
mode_auth_stag_flag, \
mode_auth_gtag_flag) \
{ \
#mode_name, \
"MODE_" #mode_name, \
EVP_CIPH_ ## mode_name ## _MODE, \
mode_auth_enc, \
mode_auth_inlen_init, \
mode_auth_ivlen_flag, \
mode_auth_stag_flag, \
mode_auth_gtag_flag \
},
#define PHP_CRYPTO_CIPHER_MODE_ENTRY(mode_name) \
PHP_CRYPTO_CIPHER_MODE_ENTRY_EX(mode_name, 0, 0, 0, 0, 0)
#define PHP_CRYPTO_CIPHER_MODE_ENTRY_NOT_DEFINED(mode_name) \
{ \
#mode_name, \
"MODE_" \
#mode_name, \
PHP_CRYPTO_CIPHER_MODE_NOT_DEFINED, \
0, 0, 0, 0, 0 \
},
#define PHP_CRYPTO_CIPHER_MODE_ENTRY_END \
{ "", "", 0, 0, 0, 0, 0, 0 }
/* Cipher authentication tag length max, min and default */
#define PHP_CRYPTO_CIPHER_AUTH_TAG_LENGTH_MIN 4
#define PHP_CRYPTO_CIPHER_AUTH_TAG_LENGTH_MAX 16
#define PHP_CRYPTO_CIPHER_AUTH_TAG_LENGTH_DEFAULT 16
/* CLASSES */
/* Class entry */
extern PHP_CRYPTO_API zend_class_entry *php_crypto_cipher_ce;
/* USER METHODS */
/* Module init for Crypto Cipher */
PHP_MINIT_FUNCTION(crypto_cipher);
/* Methods */
PHP_CRYPTO_METHOD(Cipher, getAlgorithms);
PHP_CRYPTO_METHOD(Cipher, hasAlgorithm);
PHP_CRYPTO_METHOD(Cipher, hasMode);
PHP_CRYPTO_METHOD(Cipher, __callStatic);
PHP_CRYPTO_METHOD(Cipher, __construct);
PHP_CRYPTO_METHOD(Cipher, getAlgorithmName);
PHP_CRYPTO_METHOD(Cipher, encryptInit);
PHP_CRYPTO_METHOD(Cipher, encryptUpdate);
PHP_CRYPTO_METHOD(Cipher, encryptFinish);
PHP_CRYPTO_METHOD(Cipher, encrypt);
PHP_CRYPTO_METHOD(Cipher, decryptInit);
PHP_CRYPTO_METHOD(Cipher, decryptUpdate);
PHP_CRYPTO_METHOD(Cipher, decryptFinish);
PHP_CRYPTO_METHOD(Cipher, decrypt);
PHP_CRYPTO_METHOD(Cipher, getBlockSize);
PHP_CRYPTO_METHOD(Cipher, getKeyLength);
PHP_CRYPTO_METHOD(Cipher, getIVLength);
PHP_CRYPTO_METHOD(Cipher, getMode);
PHP_CRYPTO_METHOD(Cipher, getTag);
PHP_CRYPTO_METHOD(Cipher, setTag);
PHP_CRYPTO_METHOD(Cipher, setTagLength);
PHP_CRYPTO_METHOD(Cipher, getAAD);
PHP_CRYPTO_METHOD(Cipher, setAAD);
/* API FUNCTIONS */
PHP_CRYPTO_API const EVP_CIPHER *php_crypto_get_cipher_algorithm(
char *algorithm,
phpc_str_size_t algorithm_len);
PHP_CRYPTO_API const EVP_CIPHER *php_crypto_get_cipher_algorithm_from_params(
char *algorithm,
phpc_str_size_t algorithm_len,
zval *pz_mode,
zval *pz_key_size TSRMLS_DC);
PHP_CRYPTO_API const php_crypto_cipher_mode *php_crypto_get_cipher_mode_ex(
long mode_value);
PHP_CRYPTO_API const php_crypto_cipher_mode *php_crypto_get_cipher_mode(
const EVP_CIPHER *cipher);
PHP_CRYPTO_API int php_crypto_cipher_set_tag(
EVP_CIPHER_CTX *cipher_ctx,
const php_crypto_cipher_mode *mode,
unsigned char *tag,
int tag_len TSRMLS_DC);
PHP_CRYPTO_API int php_crypto_cipher_write_aad(
EVP_CIPHER_CTX *cipher_ctx,
unsigned char *aad,
int aad_len TSRMLS_DC);
#endif /* PHP_CRYPTO_CIPHER_H */
/*
* Local variables:
* tab-width: 4
* c-basic-offset: 4
* End:
* vim600: noet sw=4 ts=4 fdm=marker
* vim<600: noet sw=4 ts=4
*/