LogDriver * afuser_dd_new(gchar *user) { AFUserDestDriver *self = g_new0(AFUserDestDriver, 1); log_drv_init_instance(&self->super); self->super.super.init = afuser_dd_init; self->super.super.deinit = afuser_dd_deinit; self->super.super.queue = afuser_dd_queue; self->username = g_string_new(user); return &self->super; }
LogDriver * afprogram_dd_new(gchar *cmdline) { AFProgramDestDriver *self = g_new0(AFProgramDestDriver, 1); log_drv_init_instance(&self->super); self->super.super.init = afprogram_dd_init; self->super.super.deinit = afprogram_dd_deinit; self->super.super.free_fn = afprogram_dd_free; self->super.super.notify = afprogram_dd_notify; self->cmdline = g_string_new(cmdline); log_writer_options_defaults(&self->writer_options); return &self->super; }
LogDriver * affile_sd_new(gchar *filename, guint32 flags) { AFFileSourceDriver *self = g_new0(AFFileSourceDriver, 1); log_drv_init_instance(&self->super); self->filename = g_string_new(filename); self->flags = flags; self->super.super.init = affile_sd_init; self->super.super.deinit = affile_sd_deinit; self->super.super.free_fn = affile_sd_free; log_reader_options_defaults(&self->reader_options); return &self->super; }
LogDriver * affile_sd_new(gchar *filename, guint32 flags) { AFFileSourceDriver *self = g_new0(AFFileSourceDriver, 1); log_drv_init_instance(&self->super); self->filename = g_string_new(filename); self->flags = flags; self->super.super.init = affile_sd_init; self->super.super.queue = affile_sd_queue; self->super.super.deinit = affile_sd_deinit; self->super.super.notify = affile_sd_notify; self->super.super.free_fn = affile_sd_free; log_reader_options_defaults(&self->reader_options); if (configuration && configuration->version < 0x0300) { static gboolean warned = FALSE; if (!warned) { msg_warning("WARNING: file source: default value of follow_freq in file sources is changing in 3.0 to '1' for all files except /proc/kmsg", NULL); warned = TRUE; } } else { if ((self->flags & AFFILE_PIPE) == 0) self->reader_options.follow_freq = 1000; if (0 || #if __linux__ (strcmp(filename, "/proc/kmsg") == 0) || #elif __FreeBSD__ (strcmp(filename, "/dev/klog") == 0) || #endif 0) { self->reader_options.follow_freq = 0; } } #if __linux__ if (strcmp(filename, "/proc/kmsg") == 0) { self->flags |= AFFILE_PRIVILEGED; } #endif return &self->super; }
void afsocket_sd_init_instance(AFSocketSourceDriver *self, SocketOptions *sock_options, guint32 flags) { log_drv_init_instance(&self->super); self->super.super.init = afsocket_sd_init; self->super.super.deinit = afsocket_sd_deinit; self->super.super.free_fn = afsocket_sd_free; self->super.super.queue = log_pipe_forward_msg; self->super.super.notify = afsocket_sd_notify; self->sock_options_ptr = sock_options; self->setup_socket = afsocket_sd_setup_socket; self->max_connections = 10; self->listen_backlog = 255; self->flags = flags | AFSOCKET_KEEP_ALIVE; log_reader_options_defaults(&self->reader_options); }
void afsocket_dd_init_instance(AFSocketDestDriver *self, SocketOptions *sock_options, guint32 flags, gchar *hostname, gchar *dest_name) { log_drv_init_instance(&self->super); log_writer_options_defaults(&self->writer_options); self->super.super.init = afsocket_dd_init; self->super.super.deinit = afsocket_dd_deinit; self->super.super.queue = log_pipe_forward_msg; self->super.super.free_fn = afsocket_dd_free; self->super.super.notify = afsocket_dd_notify; self->setup_socket = afsocket_dd_setup_socket; self->sock_options_ptr = sock_options; self->flags = flags | AFSOCKET_KEEP_ALIVE; self->hostname = hostname; self->dest_name = dest_name; }
void afsocket_sd_init_instance(AFSocketSourceDriver *self, SocketOptions *sock_options, guint32 flags) { log_drv_init_instance(&self->super); self->super.super.init = afsocket_sd_init; self->super.super.deinit = afsocket_sd_deinit; self->super.super.free_fn = afsocket_sd_free; self->super.super.queue = log_pipe_forward_msg; self->super.super.notify = afsocket_sd_notify; self->sock_options_ptr = sock_options; self->setup_socket = afsocket_sd_setup_socket; self->max_connections = 10; self->listen_backlog = 255; self->flags = flags | AFSOCKET_KEEP_ALIVE; log_reader_options_defaults(&self->reader_options); if (self->flags & AFSOCKET_LOCAL) { static gboolean warned = FALSE; self->reader_options.flags |= LR_LOCAL; if (configuration && configuration->version < 0x0302) { if (!warned) { msg_warning("WARNING: the expected message format is being changed for unix-domain transports to improve " "syslogd compatibity with syslog-ng 3.2. If you are using custom " "applications which bypass the syslog() API, you might " "need the 'expect-hostname' flag to get the old behaviour back", NULL); warned = TRUE; } } else { self->reader_options.parse_options.flags &= ~LP_EXPECT_HOSTNAME; } } if ((self->flags & AFSOCKET_SYSLOG_PROTOCOL)) { self->reader_options.parse_options.flags |= LP_SYSLOG_PROTOCOL; } }