php_openssl.h 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171
  1. /*
  2. +----------------------------------------------------------------------+
  3. | PHP Version 7 |
  4. +----------------------------------------------------------------------+
  5. | Copyright (c) 1997-2018 The PHP Group |
  6. +----------------------------------------------------------------------+
  7. | This source file is subject to version 3.01 of the PHP license, |
  8. | that is bundled with this package in the file LICENSE, and is |
  9. | available through the world-wide-web at the following url: |
  10. | http://www.php.net/license/3_01.txt |
  11. | If you did not receive a copy of the PHP license and are unable to |
  12. | obtain it through the world-wide-web, please send a note to |
  13. | license@php.net so we can mail you a copy immediately. |
  14. +----------------------------------------------------------------------+
  15. | Authors: Stig Venaas <venaas@php.net> |
  16. | Wez Furlong <wez@thebrainroom.com |
  17. +----------------------------------------------------------------------+
  18. */
  19. #ifndef PHP_OPENSSL_H
  20. #define PHP_OPENSSL_H
  21. /* HAVE_OPENSSL would include SSL MySQL stuff */
  22. #ifdef HAVE_OPENSSL_EXT
  23. extern zend_module_entry openssl_module_entry;
  24. #define phpext_openssl_ptr &openssl_module_entry
  25. #include "php_version.h"
  26. #define PHP_OPENSSL_VERSION PHP_VERSION
  27. #include <openssl/opensslv.h>
  28. #if defined(LIBRESSL_VERSION_NUMBER)
  29. /* LibreSSL version check */
  30. #if LIBRESSL_VERSION_NUMBER < 0x20700000L
  31. #define PHP_OPENSSL_API_VERSION 0x10001
  32. #else
  33. #define PHP_OPENSSL_API_VERSION 0x10100
  34. #endif
  35. #else
  36. /* OpenSSL version check */
  37. #if OPENSSL_VERSION_NUMBER < 0x10002000L
  38. #define PHP_OPENSSL_API_VERSION 0x10001
  39. #elif OPENSSL_VERSION_NUMBER < 0x10100000L
  40. #define PHP_OPENSSL_API_VERSION 0x10002
  41. #else
  42. #define PHP_OPENSSL_API_VERSION 0x10100
  43. #endif
  44. #endif
  45. #define OPENSSL_RAW_DATA 1
  46. #define OPENSSL_ZERO_PADDING 2
  47. #define OPENSSL_DONT_ZERO_PAD_KEY 4
  48. #define OPENSSL_ERROR_X509_PRIVATE_KEY_VALUES_MISMATCH 0x0B080074
  49. /* Used for client-initiated handshake renegotiation DoS protection*/
  50. #define OPENSSL_DEFAULT_RENEG_LIMIT 2
  51. #define OPENSSL_DEFAULT_RENEG_WINDOW 300
  52. #define OPENSSL_DEFAULT_STREAM_VERIFY_DEPTH 9
  53. #define OPENSSL_DEFAULT_STREAM_CIPHERS "ECDHE-RSA-AES128-GCM-SHA256:ECDHE-ECDSA-AES128-GCM-SHA256:" \
  54. "ECDHE-RSA-AES256-GCM-SHA384:ECDHE-ECDSA-AES256-GCM-SHA384:DHE-RSA-AES128-GCM-SHA256:" \
  55. "DHE-DSS-AES128-GCM-SHA256:kEDH+AESGCM:ECDHE-RSA-AES128-SHA256:ECDHE-ECDSA-AES128-SHA256:" \
  56. "ECDHE-RSA-AES128-SHA:ECDHE-ECDSA-AES128-SHA:ECDHE-RSA-AES256-SHA384:ECDHE-ECDSA-AES256-SHA384:" \
  57. "ECDHE-RSA-AES256-SHA:ECDHE-ECDSA-AES256-SHA:DHE-RSA-AES128-SHA256:DHE-RSA-AES128-SHA:" \
  58. "DHE-DSS-AES128-SHA256:DHE-RSA-AES256-SHA256:DHE-DSS-AES256-SHA:DHE-RSA-AES256-SHA:AES128-GCM-SHA256:" \
  59. "AES256-GCM-SHA384:AES128:AES256:HIGH:!SSLv2:!aNULL:!eNULL:!EXPORT:!DES:!MD5:!RC4:!ADH"
  60. #include <openssl/err.h>
  61. struct php_openssl_errors {
  62. int buffer[ERR_NUM_ERRORS];
  63. int top;
  64. int bottom;
  65. };
  66. ZEND_BEGIN_MODULE_GLOBALS(openssl)
  67. struct php_openssl_errors *errors;
  68. ZEND_END_MODULE_GLOBALS(openssl)
  69. #define OPENSSL_G(v) ZEND_MODULE_GLOBALS_ACCESSOR(openssl, v)
  70. #if defined(ZTS) && defined(COMPILE_DL_OPENSSL)
  71. ZEND_TSRMLS_CACHE_EXTERN();
  72. #endif
  73. php_stream_transport_factory_func php_openssl_ssl_socket_factory;
  74. void php_openssl_store_errors();
  75. PHP_MINIT_FUNCTION(openssl);
  76. PHP_MSHUTDOWN_FUNCTION(openssl);
  77. PHP_MINFO_FUNCTION(openssl);
  78. PHP_GINIT_FUNCTION(openssl);
  79. PHP_GSHUTDOWN_FUNCTION(openssl);
  80. PHP_FUNCTION(openssl_pkey_get_private);
  81. PHP_FUNCTION(openssl_pkey_get_public);
  82. PHP_FUNCTION(openssl_pkey_free);
  83. PHP_FUNCTION(openssl_pkey_new);
  84. PHP_FUNCTION(openssl_pkey_export);
  85. PHP_FUNCTION(openssl_pkey_export_to_file);
  86. PHP_FUNCTION(openssl_pkey_get_details);
  87. PHP_FUNCTION(openssl_sign);
  88. PHP_FUNCTION(openssl_verify);
  89. PHP_FUNCTION(openssl_seal);
  90. PHP_FUNCTION(openssl_open);
  91. PHP_FUNCTION(openssl_private_encrypt);
  92. PHP_FUNCTION(openssl_private_decrypt);
  93. PHP_FUNCTION(openssl_public_encrypt);
  94. PHP_FUNCTION(openssl_public_decrypt);
  95. PHP_FUNCTION(openssl_pbkdf2);
  96. PHP_FUNCTION(openssl_pkcs7_verify);
  97. PHP_FUNCTION(openssl_pkcs7_decrypt);
  98. PHP_FUNCTION(openssl_pkcs7_sign);
  99. PHP_FUNCTION(openssl_pkcs7_encrypt);
  100. PHP_FUNCTION(openssl_pkcs7_read);
  101. PHP_FUNCTION(openssl_error_string);
  102. PHP_FUNCTION(openssl_x509_read);
  103. PHP_FUNCTION(openssl_x509_free);
  104. PHP_FUNCTION(openssl_x509_parse);
  105. PHP_FUNCTION(openssl_x509_checkpurpose);
  106. PHP_FUNCTION(openssl_x509_export);
  107. PHP_FUNCTION(openssl_x509_fingerprint);
  108. PHP_FUNCTION(openssl_x509_export_to_file);
  109. PHP_FUNCTION(openssl_x509_check_private_key);
  110. PHP_FUNCTION(openssl_pkcs12_export);
  111. PHP_FUNCTION(openssl_pkcs12_export_to_file);
  112. PHP_FUNCTION(openssl_pkcs12_read);
  113. PHP_FUNCTION(openssl_csr_new);
  114. PHP_FUNCTION(openssl_csr_export);
  115. PHP_FUNCTION(openssl_csr_export_to_file);
  116. PHP_FUNCTION(openssl_csr_sign);
  117. PHP_FUNCTION(openssl_csr_get_subject);
  118. PHP_FUNCTION(openssl_csr_get_public_key);
  119. PHP_FUNCTION(openssl_spki_new);
  120. PHP_FUNCTION(openssl_spki_verify);
  121. PHP_FUNCTION(openssl_spki_export);
  122. PHP_FUNCTION(openssl_spki_export_challenge);
  123. PHP_FUNCTION(openssl_get_cert_locations);
  124. #ifdef PHP_WIN32
  125. #define PHP_OPENSSL_BIO_MODE_R(flags) (((flags) & PKCS7_BINARY) ? "rb" : "r")
  126. #define PHP_OPENSSL_BIO_MODE_W(flags) (((flags) & PKCS7_BINARY) ? "wb" : "w")
  127. #else
  128. #define PHP_OPENSSL_BIO_MODE_R(flags) "r"
  129. #define PHP_OPENSSL_BIO_MODE_W(flags) "w"
  130. #endif
  131. #else
  132. #define phpext_openssl_ptr NULL
  133. #endif
  134. #endif
  135. /*
  136. * Local variables:
  137. * tab-width: 4
  138. * c-basic-offset: 4
  139. * End:
  140. */