syslog.c 6.3 KB

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