syslog.c 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207
  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. | Author: Stig Sæther Bakken <ssb@php.net> |
  16. +----------------------------------------------------------------------+
  17. */
  18. #include "php.h"
  19. #ifdef HAVE_SYSLOG_H
  20. #include "php_ini.h"
  21. #include "zend_globals.h"
  22. #include <stdlib.h>
  23. #if HAVE_UNISTD_H
  24. #include <unistd.h>
  25. #endif
  26. #include <string.h>
  27. #include <errno.h>
  28. #include <stdio.h>
  29. #include "basic_functions.h"
  30. #include "php_ext_syslog.h"
  31. /* {{{ PHP_MINIT_FUNCTION
  32. */
  33. PHP_MINIT_FUNCTION(syslog)
  34. {
  35. /* error levels */
  36. REGISTER_LONG_CONSTANT("LOG_EMERG", LOG_EMERG, CONST_CS | CONST_PERSISTENT); /* system unusable */
  37. REGISTER_LONG_CONSTANT("LOG_ALERT", LOG_ALERT, CONST_CS | CONST_PERSISTENT); /* immediate action required */
  38. REGISTER_LONG_CONSTANT("LOG_CRIT", LOG_CRIT, CONST_CS | CONST_PERSISTENT); /* critical conditions */
  39. REGISTER_LONG_CONSTANT("LOG_ERR", LOG_ERR, CONST_CS | CONST_PERSISTENT);
  40. REGISTER_LONG_CONSTANT("LOG_WARNING", LOG_WARNING, CONST_CS | CONST_PERSISTENT);
  41. REGISTER_LONG_CONSTANT("LOG_NOTICE", LOG_NOTICE, CONST_CS | CONST_PERSISTENT);
  42. REGISTER_LONG_CONSTANT("LOG_INFO", LOG_INFO, CONST_CS | CONST_PERSISTENT);
  43. REGISTER_LONG_CONSTANT("LOG_DEBUG", LOG_DEBUG, CONST_CS | CONST_PERSISTENT);
  44. /* facility: type of program logging the message */
  45. REGISTER_LONG_CONSTANT("LOG_KERN", LOG_KERN, CONST_CS | CONST_PERSISTENT);
  46. REGISTER_LONG_CONSTANT("LOG_USER", LOG_USER, CONST_CS | CONST_PERSISTENT); /* generic user level */
  47. REGISTER_LONG_CONSTANT("LOG_MAIL", LOG_MAIL, CONST_CS | CONST_PERSISTENT); /* log to email */
  48. REGISTER_LONG_CONSTANT("LOG_DAEMON", LOG_DAEMON, CONST_CS | CONST_PERSISTENT); /* other system daemons */
  49. REGISTER_LONG_CONSTANT("LOG_AUTH", LOG_AUTH, CONST_CS | CONST_PERSISTENT);
  50. REGISTER_LONG_CONSTANT("LOG_SYSLOG", LOG_SYSLOG, CONST_CS | CONST_PERSISTENT);
  51. REGISTER_LONG_CONSTANT("LOG_LPR", LOG_LPR, CONST_CS | CONST_PERSISTENT);
  52. #ifdef LOG_NEWS
  53. /* No LOG_NEWS on HP-UX */
  54. REGISTER_LONG_CONSTANT("LOG_NEWS", LOG_NEWS, CONST_CS | CONST_PERSISTENT); /* usenet new */
  55. #endif
  56. #ifdef LOG_UUCP
  57. /* No LOG_UUCP on HP-UX */
  58. REGISTER_LONG_CONSTANT("LOG_UUCP", LOG_UUCP, CONST_CS | CONST_PERSISTENT);
  59. #endif
  60. #ifdef LOG_CRON
  61. /* apparently some systems don't have this one */
  62. REGISTER_LONG_CONSTANT("LOG_CRON", LOG_CRON, CONST_CS | CONST_PERSISTENT);
  63. #endif
  64. #ifdef LOG_AUTHPRIV
  65. /* AIX doesn't have LOG_AUTHPRIV */
  66. REGISTER_LONG_CONSTANT("LOG_AUTHPRIV", LOG_AUTHPRIV, CONST_CS | CONST_PERSISTENT);
  67. #endif
  68. #ifndef PHP_WIN32
  69. REGISTER_LONG_CONSTANT("LOG_LOCAL0", LOG_LOCAL0, CONST_CS | CONST_PERSISTENT);
  70. REGISTER_LONG_CONSTANT("LOG_LOCAL1", LOG_LOCAL1, CONST_CS | CONST_PERSISTENT);
  71. REGISTER_LONG_CONSTANT("LOG_LOCAL2", LOG_LOCAL2, CONST_CS | CONST_PERSISTENT);
  72. REGISTER_LONG_CONSTANT("LOG_LOCAL3", LOG_LOCAL3, CONST_CS | CONST_PERSISTENT);
  73. REGISTER_LONG_CONSTANT("LOG_LOCAL4", LOG_LOCAL4, CONST_CS | CONST_PERSISTENT);
  74. REGISTER_LONG_CONSTANT("LOG_LOCAL5", LOG_LOCAL5, CONST_CS | CONST_PERSISTENT);
  75. REGISTER_LONG_CONSTANT("LOG_LOCAL6", LOG_LOCAL6, CONST_CS | CONST_PERSISTENT);
  76. REGISTER_LONG_CONSTANT("LOG_LOCAL7", LOG_LOCAL7, CONST_CS | CONST_PERSISTENT);
  77. #endif
  78. /* options */
  79. REGISTER_LONG_CONSTANT("LOG_PID", LOG_PID, CONST_CS | CONST_PERSISTENT);
  80. REGISTER_LONG_CONSTANT("LOG_CONS", LOG_CONS, CONST_CS | CONST_PERSISTENT);
  81. REGISTER_LONG_CONSTANT("LOG_ODELAY", LOG_ODELAY, CONST_CS | CONST_PERSISTENT);
  82. REGISTER_LONG_CONSTANT("LOG_NDELAY", LOG_NDELAY, CONST_CS | CONST_PERSISTENT);
  83. #ifdef LOG_NOWAIT
  84. REGISTER_LONG_CONSTANT("LOG_NOWAIT", LOG_NOWAIT, CONST_CS | CONST_PERSISTENT);
  85. #endif
  86. #ifdef LOG_PERROR
  87. /* AIX doesn't have LOG_PERROR */
  88. REGISTER_LONG_CONSTANT("LOG_PERROR", LOG_PERROR, CONST_CS | CONST_PERSISTENT); /*log to stderr*/
  89. #endif
  90. BG(syslog_device)=NULL;
  91. return SUCCESS;
  92. }
  93. /* }}} */
  94. PHP_RINIT_FUNCTION(syslog)
  95. {
  96. BG(syslog_device) = NULL;
  97. return SUCCESS;
  98. }
  99. #ifdef PHP_WIN32
  100. PHP_RSHUTDOWN_FUNCTION(syslog)
  101. {
  102. closelog();
  103. return SUCCESS;
  104. }
  105. #endif
  106. PHP_MSHUTDOWN_FUNCTION(syslog)
  107. {
  108. if (BG(syslog_device)) {
  109. free(BG(syslog_device));
  110. BG(syslog_device) = NULL;
  111. }
  112. return SUCCESS;
  113. }
  114. void php_openlog(const char *ident, int option, int facility)
  115. {
  116. openlog(ident, option, facility);
  117. PG(have_called_openlog) = 1;
  118. }
  119. /* {{{ proto bool openlog(string ident, int option, int facility)
  120. Open connection to system logger */
  121. /*
  122. ** OpenLog("nettopp", $LOG_PID, $LOG_LOCAL1);
  123. ** Syslog($LOG_EMERG, "help me!")
  124. ** CloseLog();
  125. */
  126. PHP_FUNCTION(openlog)
  127. {
  128. char *ident;
  129. zend_long option, facility;
  130. size_t ident_len;
  131. ZEND_PARSE_PARAMETERS_START(3, 3)
  132. Z_PARAM_STRING(ident, ident_len)
  133. Z_PARAM_LONG(option)
  134. Z_PARAM_LONG(facility)
  135. ZEND_PARSE_PARAMETERS_END();
  136. if (BG(syslog_device)) {
  137. free(BG(syslog_device));
  138. }
  139. BG(syslog_device) = zend_strndup(ident, ident_len);
  140. if(BG(syslog_device) == NULL) {
  141. RETURN_FALSE;
  142. }
  143. php_openlog(BG(syslog_device), option, facility);
  144. RETURN_TRUE;
  145. }
  146. /* }}} */
  147. /* {{{ proto bool closelog(void)
  148. Close connection to system logger */
  149. PHP_FUNCTION(closelog)
  150. {
  151. if (zend_parse_parameters_none() == FAILURE) {
  152. return;
  153. }
  154. closelog();
  155. if (BG(syslog_device)) {
  156. free(BG(syslog_device));
  157. BG(syslog_device)=NULL;
  158. }
  159. RETURN_TRUE;
  160. }
  161. /* }}} */
  162. /* {{{ proto bool syslog(int priority, string message)
  163. Generate a system log message */
  164. PHP_FUNCTION(syslog)
  165. {
  166. zend_long priority;
  167. char *message;
  168. size_t message_len;
  169. ZEND_PARSE_PARAMETERS_START(2, 2)
  170. Z_PARAM_LONG(priority)
  171. Z_PARAM_STRING(message, message_len)
  172. ZEND_PARSE_PARAMETERS_END();
  173. php_syslog(priority, "%s", message);
  174. RETURN_TRUE;
  175. }
  176. /* }}} */
  177. #endif
  178. /*
  179. * Local variables:
  180. * tab-width: 4
  181. * c-basic-offset: 4
  182. * End:
  183. * vim600: sw=4 ts=4 fdm=marker
  184. * vim<600: sw=4 ts=4
  185. */