#include "command_service.h" #include "commands.h" #include "conf.h" #include #include static GSocketService *ss = NULL; static gboolean service_incoming(GSocketService *service, GSocketConnection *connection, GObject *source_object, gpointer user_data) { GError *error = NULL; GSocket *socket = g_socket_connection_get_socket(connection); GDataInputStream *input = g_data_input_stream_new(g_io_stream_get_input_stream((GIOStream*)connection)); g_data_input_stream_set_newline_type(input, G_DATA_STREAM_NEWLINE_TYPE_LF); gchar *line; gsize size; while(g_socket_is_connected(socket) == TRUE && (line = g_data_input_stream_read_line(input, &size, NULL, &error)) != NULL) { commands_handle(connection, line, &error); if(error != NULL) { g_warning(error->message); gchar *error_buffer = g_strdup_printf("%s\n", error->message); g_socket_send(socket, error_buffer, strlen(error_buffer), NULL, NULL); g_free(error_buffer); g_error_free(error); error = NULL; } } g_object_unref(input); if(error != NULL) { g_warning(error->message); g_error_free(error); } return FALSE; } gboolean server_start() { GError *error = NULL; ss = g_threaded_socket_service_new(10); if(g_socket_listener_add_inet_port((GSocketListener*)ss, conf_get_int("audist", "command_port"), NULL, &error) == FALSE) { g_warning("failed to set port: %s", error->message); g_error_free(error); return FALSE; } g_signal_connect(ss, "run", (GCallback)service_incoming, NULL); g_socket_service_start(ss); return TRUE; } void server_stop() { g_socket_service_stop(ss); g_object_unref(ss); }