123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129 |
- #include <stdio.h>
- #include <string.h>
- #include <stdlib.h>
- #include "php.h"
- #include "php_syslog.h"
- #include "zend.h"
- #include "zend_smart_string.h"
- #ifdef HAVE_STD_SYSLOG
- #define syslog std_syslog
- #endif
- PHPAPI void php_syslog_str(int priority, const zend_string* message)
- {
- smart_string sbuf = {0};
- if (PG(syslog_filter) == PHP_SYSLOG_FILTER_RAW) {
-
- syslog(priority, "%s", ZSTR_VAL(message));
- return;
- }
-
- for (size_t i = 0; i < ZSTR_LEN(message); ++i) {
- unsigned char c = ZSTR_VAL(message)[i];
-
- if (((0x20 <= c) && (c <= 0x7e))) {
- smart_string_appendc(&sbuf, c);
- } else if ((c >= 0x80) && (PG(syslog_filter) != PHP_SYSLOG_FILTER_ASCII)) {
- smart_string_appendc(&sbuf, c);
- } else if (c == '\n') {
-
- syslog(priority, "%.*s", (int)sbuf.len, sbuf.c);
- smart_string_reset(&sbuf);
- } else if ((c < 0x20) && (PG(syslog_filter) == PHP_SYSLOG_FILTER_ALL)) {
- smart_string_appendc(&sbuf, c);
- } else {
- const char xdigits[] = "0123456789abcdef";
- smart_string_appendl(&sbuf, "\\x", 2);
- smart_string_appendc(&sbuf, xdigits[c >> 4]);
- smart_string_appendc(&sbuf, xdigits[c & 0xf]);
- }
- }
-
- syslog(priority, "%.*s", (int)sbuf.len, sbuf.c);
- smart_string_free(&sbuf);
- }
- void php_openlog(const char *ident, int option, int facility)
- {
- openlog(ident, option, facility);
- PG(have_called_openlog) = 1;
- }
- void php_closelog(void)
- {
- closelog();
- PG(have_called_openlog) = 0;
- }
- #ifdef PHP_WIN32
- PHPAPI void php_syslog(int priority, const char *format, ...)
- {
- va_list args;
-
- if (!PG(have_called_openlog)) {
- php_openlog(PG(syslog_ident), 0, PG(syslog_facility));
- }
- va_start(args, format);
- vsyslog(priority, format, args);
- va_end(args);
- }
- #else
- PHPAPI void php_syslog(int priority, const char *format, ...)
- {
- zend_string *fbuf = NULL;
- va_list args;
-
- if (!PG(have_called_openlog)) {
- php_openlog(PG(syslog_ident), 0, PG(syslog_facility));
- }
- va_start(args, format);
- fbuf = zend_vstrpprintf(0, format, args);
- va_end(args);
- php_syslog_str(priority, fbuf);
- zend_string_release(fbuf);
- }
- #endif
|