[Freeswitch-svn] [commit] r1155 - in freeswitch/branches/james: conf src src/include src/mod/loggers/mod_syslog

james at freeswitch.org james at freeswitch.org
Wed Jun 7 14:22:30 EDT 2006


Author: james
Date: Fri Apr 14 11:28:04 2006
New Revision: 1155

Added:
   freeswitch/branches/james/src/mod/loggers/mod_syslog/
   freeswitch/branches/james/src/mod/loggers/mod_syslog/mod_syslog.c
Modified:
   freeswitch/branches/james/conf/freeswitch.conf
   freeswitch/branches/james/src/include/switch_utils.h
   freeswitch/branches/james/src/switch_utils.c

Log:
Added syslog support, still need work on the separate levels.


Modified: freeswitch/branches/james/conf/freeswitch.conf
==============================================================================
--- freeswitch/branches/james/conf/freeswitch.conf	(original)
+++ freeswitch/branches/james/conf/freeswitch.conf	Fri Apr 14 11:28:04 2006
@@ -18,6 +18,7 @@
 
 ; Loggers (I'd load these first)
 load => mod_console
+load => mod_syslog
 
 ; Event Handlers
 ;load => mod_event_multicast
@@ -67,6 +68,23 @@
 ; ASR /TTS
 ;load => mod_cepstral
 
+;---- SYSLOG
+;--------------------------------------------------------------------------------
+; emerg   - system is unusable 
+; alert   - action must be taken immediately 
+; crit    - critical conditions 
+; err     - error conditions 
+; warning - warning conditions 
+; notice  - normal, but significant, condition 
+; info    - informational message 
+; debug   - debug-level message
+;
+[+syslog.conf]
+[settings]
+ident    => freeswitch
+facility => user
+format   => ${time} - ${message}
+level    => debug,info,warning-alert
 
 
 ;---- IAX PROTOCOL

Modified: freeswitch/branches/james/src/include/switch_utils.h
==============================================================================
--- freeswitch/branches/james/src/include/switch_utils.h	(original)
+++ freeswitch/branches/james/src/include/switch_utils.h	Fri Apr 14 11:28:04 2006
@@ -174,6 +174,8 @@
 */
 SWITCH_DECLARE(char *) switch_cut_path(char *in);
 
+SWITCH_DECLARE(char *) switch_string_replace(const char *string, const char *search, const char *replace);
+SWITCH_DECLARE(switch_status) switch_string_match(const char *string, int string_len, const char *search, int search_len);
 
 #ifdef __cplusplus
 }

Added: freeswitch/branches/james/src/mod/loggers/mod_syslog/mod_syslog.c
==============================================================================
--- (empty file)
+++ freeswitch/branches/james/src/mod/loggers/mod_syslog/mod_syslog.c	Fri Apr 14 11:28:04 2006
@@ -0,0 +1,167 @@
+/* 
+ * FreeSWITCH Modular Media Switching Software Library / Soft-Switch Application
+ * Copyright (C) 2005/2006, James Martelletti <james at nerdc0re.com>
+ *
+ * Version: MPL 1.1
+ *
+ * The contents of this file are subject to the Mozilla Public License Version
+ * 1.1 (the "License"); you may not use this file except in compliance with
+ * the License. You may obtain a copy of the License at
+ * http://www.mozilla.org/MPL/
+ *
+ * Software distributed under the License is distributed on an "AS IS" basis,
+ * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
+ * for the specific language governing rights and limitations under the
+ * License.
+ *
+ * The Original Code is FreeSWITCH Modular Media Switching Software Library / Soft-Switch Application
+ *
+ * The Initial Developer of the Original Code is
+ * James Martelletti <james at nerdc0re.com>
+ * Portions created by the Initial Developer are Copyright (C)
+ * the Initial Developer. All Rights Reserved.
+ *
+ * Contributor(s):
+ * 
+ * James Martelletti <james at nerdc0re.com>
+ *
+ *
+ * mod_syslog.c -- System Logging
+ *
+ */
+#include <switch.h>
+#include <stdlib.h>
+#include <syslog.h>
+
+#define DEFAULT_IDENT    "freeswitch"
+#define DEFAULT_FACILITY "user"
+#define DEFAULT_LEVEL    "warning"
+#define DEFAULT_FORMAT   "[message]"
+#define MAX_LENGTH       1024
+
+static const char modname[] = "mod_syslog";
+static switch_status load_config(void);
+
+static struct {
+	char *ident;
+	char *facility;
+	char *level;
+	char *format;
+} globals;
+
+SWITCH_DECLARE_GLOBAL_STRING_FUNC(set_global_ident, globals.ident)
+SWITCH_DECLARE_GLOBAL_STRING_FUNC(set_global_level, globals.level)
+SWITCH_DECLARE_GLOBAL_STRING_FUNC(set_global_format, globals.format)
+SWITCH_DECLARE_GLOBAL_STRING_FUNC(set_global_facility, globals.facility)
+
+static switch_loadable_module_interface console_module_interface = {
+	/*.module_name */ modname,
+	/*.endpoint_interface */ NULL,
+	/*.timer_interface */ NULL,
+	/*.dialplan_interface */ NULL,
+	/*.codec_interface */ NULL,
+	/*.application_interface */ NULL,
+	/*.api_interface */ NULL,
+	/*.file_interface */ NULL,
+	/*.speech_interface */ NULL,
+	/*.directory_interface */ NULL
+};
+
+static switch_status mod_syslog_logger(const switch_log_node *node, switch_log_level level)
+{
+	char *message = NULL;
+	char line_no[sizeof(int)*8+1];
+	char date[80] = "";
+	switch_time_exp_t time;
+	switch_size_t retsize;
+
+	message = (char *)malloc(strlen(globals.format)+2);
+
+	switch_copy_string(message, globals.format, strlen(globals.format)+1);
+
+	message = switch_string_replace(message, "${message}", node->content);
+	
+	if (switch_time_exp_lt(&time, node->timestamp) != SWITCH_STATUS_SUCCESS) {
+		return SWITCH_STATUS_FALSE;
+	}
+	
+	switch_strftime(date, &retsize, sizeof(date), "%Y-%m-%d %T", &time);
+	message = switch_string_replace(message, "${time}", date);
+	
+	message = switch_string_replace(message, "${file}", node->file);
+	message = switch_string_replace(message, "${func}", node->func);
+	
+	snprintf(line_no, sizeof(line_no), "%d", node->line);
+	message = switch_string_replace(message, "${line}", line_no);
+	
+	if (!switch_strlen_zero(message)) {
+		syslog(LOG_ERR, "%s", message);
+	}
+
+	free(message);
+	
+	return SWITCH_STATUS_SUCCESS;
+}
+
+SWITCH_MOD_DECLARE(switch_status) switch_module_load(const switch_loadable_module_interface **interface, char *filename)
+{
+	*interface = &console_module_interface;
+
+	switch_log_bind_logger(mod_syslog_logger, SWITCH_LOG_DEBUG);
+
+	load_config();
+
+	openlog(globals.ident, LOG_PID, LOG_USER);
+	
+	return SWITCH_STATUS_SUCCESS;
+}
+
+SWITCH_MOD_DECLARE(switch_status) switch_module_unload(const switch_loadable_module_interface **interface)
+{
+	closelog();
+	
+	return SWITCH_STATUS_SUCCESS;
+}
+
+static switch_status load_config(void)
+{
+	switch_config cfg;
+	char *var, *val;
+	char *cf = "syslog.conf";
+
+	if (!switch_config_open_file(&cfg, cf)) {
+		switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_DEBUG, "open of %s failed\n", cf);
+		return SWITCH_STATUS_TERM;
+	}
+
+	while (switch_config_next_pair(&cfg, &var, &val)) {
+		if (!strcasecmp(cfg.category, "settings")) {
+			if (!strcmp(var, "ident")) {
+				set_global_ident(val);
+			} else if (!strcmp(var, "facility")) {
+				set_global_facility(val);
+			} else if (!strcmp(var, "format")) {
+				set_global_format(val);
+			} else if (!strcmp(var, "level")) {
+				set_global_level(val);;
+			}
+		}
+	}
+	
+	switch_config_close_file(&cfg);
+
+	if (switch_strlen_zero(globals.ident)) {
+		set_global_ident(DEFAULT_IDENT);
+	}
+	if (switch_strlen_zero(globals.facility)) {
+		set_global_facility(DEFAULT_FACILITY);
+	}
+	if (switch_strlen_zero(globals.format)) {
+		set_global_format(DEFAULT_FORMAT);
+	}
+	if (switch_strlen_zero(globals.level)) {
+		set_global_level(DEFAULT_LEVEL);
+	}
+
+	return SWITCH_STATUS_SUCCESS;
+}

Modified: freeswitch/branches/james/src/switch_utils.c
==============================================================================
--- freeswitch/branches/james/src/switch_utils.c	(original)
+++ freeswitch/branches/james/src/switch_utils.c	Fri Apr 14 11:28:04 2006
@@ -30,6 +30,9 @@
  *
  */
 #include <switch.h>
+#include <stdio.h>
+#include <string.h>
+#include <stdlib.h>
 
 SWITCH_DECLARE(char *) switch_priority_name(switch_priority_t priority)
 {
@@ -141,6 +144,52 @@
 	return SWITCH_STATUS_SUCCESS;
 }
 
+SWITCH_DECLARE(switch_status) switch_string_match(const char *string, int string_len, const char *search, int search_len)
+{
+	int i;
+
+	for (i = 0; (i < search_len) && (i < string_len); i++) {
+		if (string[i] != search[i]) {
+			return SWITCH_STATUS_FALSE;
+		}
+	}	
+	
+	if (i == search_len) {
+		return SWITCH_STATUS_SUCCESS;
+	}
+
+	return SWITCH_STATUS_FALSE;
+}
+
+SWITCH_DECLARE(char *) switch_string_replace(const char *string, const char *search, const char *replace)
+{
+	int string_len = strlen(string);
+	int search_len = strlen(search);
+	int replace_len = strlen(replace);
+	int i, n;
+	int dest_len = 0;
+	char *dest;
+  
+	dest = (char *)malloc(sizeof(char));
+
+	for (i = 0; i < string_len; i++) {
+		if (switch_string_match(string + i, string_len - i, search, search_len) == SWITCH_STATUS_SUCCESS) {
+			for (n = 0; n < replace_len; n++) {
+				dest[dest_len] = replace[n];
+				dest_len++;
+				dest = (char *)realloc(dest, sizeof(char)*(dest_len+1));
+			}
+			i += search_len-1;
+		} else {
+			dest[dest_len] = string[i];
+			dest_len++;
+			dest = (char *)realloc(dest, sizeof(char)*(dest_len+1));
+		}
+	}
+
+	dest[dest_len] = 0;
+	return dest;
+}
 
 SWITCH_DECLARE(int) switch_socket_waitfor(switch_pollfd_t *poll, int ms)
 {



More information about the Freeswitch-svn mailing list