client: use GLib logging

This commit is contained in:
Max Kellermann 2008-12-29 17:28:56 +01:00
parent e0fe4eb722
commit 173021e4eb

View File

@ -19,7 +19,6 @@
#include "client.h" #include "client.h"
#include "command.h" #include "command.h"
#include "conf.h" #include "conf.h"
#include "log.h"
#include "listen.h" #include "listen.h"
#include "permission.h" #include "permission.h"
#include "utils.h" #include "utils.h"
@ -38,6 +37,10 @@
#include <unistd.h> #include <unistd.h>
#include <string.h> #include <string.h>
#undef G_LOG_DOMAIN
#define G_LOG_DOMAIN "client"
#define LOG_LEVEL_SECURE G_LOG_LEVEL_INFO
#define GREETING "OK MPD " PROTOCOL_VERSION "\n" #define GREETING "OK MPD " PROTOCOL_VERSION "\n"
#define CLIENT_LIST_MODE_BEGIN "command_list_begin" #define CLIENT_LIST_MODE_BEGIN "command_list_begin"
@ -192,7 +195,8 @@ static void client_close(struct client *client)
g_queue_foreach(client->deferred_send, deferred_buffer_free, NULL); g_queue_foreach(client->deferred_send, deferred_buffer_free, NULL);
g_queue_free(client->deferred_send); g_queue_free(client->deferred_send);
SECURE("client %i: closed\n", client->num); g_log(G_LOG_DOMAIN, LOG_LEVEL_SECURE,
"client %i: closed", client->num);
free(client); free(client);
} }
@ -243,7 +247,7 @@ void client_new(int fd, const struct sockaddr *addr, int uid)
struct client *client; struct client *client;
if (num_clients >= client_max_connections) { if (num_clients >= client_max_connections) {
ERROR("Max Connections Reached!\n"); g_warning("Max Connections Reached!");
xclose(fd); xclose(fd);
return; return;
} }
@ -253,8 +257,9 @@ void client_new(int fd, const struct sockaddr *addr, int uid)
++num_clients; ++num_clients;
client_init(client, fd); client_init(client, fd);
client->uid = uid; client->uid = uid;
SECURE("client %i: opened from %s\n", client->num, g_log(G_LOG_DOMAIN, LOG_LEVEL_SECURE,
sockaddr_to_tmp_string(addr)); "client %i: opened from %s\n", client->num,
sockaddr_to_tmp_string(addr));
} }
static int client_process_line(struct client *client, char *line) static int client_process_line(struct client *client, char *line)
@ -277,15 +282,15 @@ static int client_process_line(struct client *client, char *line)
} else if (client->idle_waiting) { } else if (client->idle_waiting) {
/* during idle mode, clients must not send anything /* during idle mode, clients must not send anything
except "noidle" */ except "noidle" */
ERROR("client %i: command \"%s\" during idle\n", g_warning("client %i: command \"%s\" during idle",
client->num, line); client->num, line);
return COMMAND_RETURN_CLOSE; return COMMAND_RETURN_CLOSE;
} }
if (client->cmd_list_OK >= 0) { if (client->cmd_list_OK >= 0) {
if (strcmp(line, CLIENT_LIST_MODE_END) == 0) { if (strcmp(line, CLIENT_LIST_MODE_END) == 0) {
DEBUG("client %i: process command " g_debug("client %i: process command list",
"list\n", client->num); client->num);
/* for scalability reasons, we have prepended /* for scalability reasons, we have prepended
each new command; now we have to reverse it each new command; now we have to reverse it
@ -295,8 +300,8 @@ static int client_process_line(struct client *client, char *line)
ret = command_process_list(client, ret = command_process_list(client,
client->cmd_list_OK, client->cmd_list_OK,
client->cmd_list); client->cmd_list);
DEBUG("client %i: process command " g_debug("client %i: process command "
"list returned %i\n", client->num, ret); "list returned %i", client->num, ret);
if (ret == COMMAND_RETURN_CLOSE || if (ret == COMMAND_RETURN_CLOSE ||
client_is_expired(client)) client_is_expired(client))
@ -314,14 +319,11 @@ static int client_process_line(struct client *client, char *line)
client->cmd_list_size += len; client->cmd_list_size += len;
if (client->cmd_list_size > if (client->cmd_list_size >
client_max_command_list_size) { client_max_command_list_size) {
ERROR("client %i: command " g_warning("client %i: command list size (%lu) "
"list size (%lu) is " "is larger than the max (%lu)",
"larger than the max " client->num,
"(%lu)\n", (unsigned long)client->cmd_list_size,
client->num, (unsigned long)client_max_command_list_size);
(unsigned long)client->cmd_list_size,
(unsigned long)
client_max_command_list_size);
return COMMAND_RETURN_CLOSE; return COMMAND_RETURN_CLOSE;
} else } else
new_cmd_list_ptr(client, line); new_cmd_list_ptr(client, line);
@ -334,11 +336,11 @@ static int client_process_line(struct client *client, char *line)
client->cmd_list_OK = 1; client->cmd_list_OK = 1;
ret = 1; ret = 1;
} else { } else {
DEBUG("client %i: process command \"%s\"\n", g_debug("client %i: process command \"%s\"",
client->num, line); client->num, line);
ret = command_process(client, line); ret = command_process(client, line);
DEBUG("client %i: command returned %i\n", g_debug("client %i: command returned %i",
client->num, ret); client->num, ret);
if (ret == COMMAND_RETURN_CLOSE || if (ret == COMMAND_RETURN_CLOSE ||
client_is_expired(client)) client_is_expired(client))
@ -391,8 +393,8 @@ static int client_input_received(struct client *client, size_t bytesRead)
the beginning */ the beginning */
if (client->bufferLength == sizeof(client->buffer)) { if (client->bufferLength == sizeof(client->buffer)) {
if (client->bufferPos == 0) { if (client->bufferPos == 0) {
ERROR("client %i: buffer overflow\n", g_warning("client %i: buffer overflow",
client->num); client->num);
return COMMAND_RETURN_CLOSE; return COMMAND_RETURN_CLOSE;
} }
assert(client->bufferLength >= client->bufferPos assert(client->bufferLength >= client->bufferPos
@ -484,7 +486,7 @@ int client_manager_io(void)
if (errno == EINTR) if (errno == EINTR)
return 0; return 0;
FATAL("select() failed: %s\n", strerror(errno)); g_error("select() failed: %s", strerror(errno));
} }
registered_IO_consume_fds(&ret, &rfds, &wfds, &efds); registered_IO_consume_fds(&ret, &rfds, &wfds, &efds);
@ -525,9 +527,9 @@ void client_manager_init(void)
if (param) { if (param) {
client_timeout = strtol(param->value, &test, 10); client_timeout = strtol(param->value, &test, 10);
if (*test != '\0' || client_timeout <= 0) { if (*test != '\0' || client_timeout <= 0) {
FATAL("connection timeout \"%s\" is not a positive " g_error("connection timeout \"%s\" is not a positive "
"integer, line %i\n", CONF_CONN_TIMEOUT, "integer, line %i",
param->line); CONF_CONN_TIMEOUT, param->line);
} }
} }
@ -536,8 +538,9 @@ void client_manager_init(void)
if (param) { if (param) {
client_max_connections = strtol(param->value, &test, 10); client_max_connections = strtol(param->value, &test, 10);
if (*test != '\0' || client_max_connections <= 0) { if (*test != '\0' || client_max_connections <= 0) {
FATAL("max connections \"%s\" is not a positive integer" g_error("max connections \"%s\" is not a positive integer"
", line %i\n", param->value, param->line); ", line %i",
param->value, param->line);
} }
} else } else
client_max_connections = CLIENT_MAX_CONNECTIONS_DEFAULT; client_max_connections = CLIENT_MAX_CONNECTIONS_DEFAULT;
@ -547,8 +550,9 @@ void client_manager_init(void)
if (param) { if (param) {
long tmp = strtol(param->value, &test, 10); long tmp = strtol(param->value, &test, 10);
if (*test != '\0' || tmp <= 0) { if (*test != '\0' || tmp <= 0) {
FATAL("max command list size \"%s\" is not a positive " g_error("max command list size \"%s\" is not a positive "
"integer, line %i\n", param->value, param->line); "integer, line %i",
param->value, param->line);
} }
client_max_command_list_size = tmp * 1024; client_max_command_list_size = tmp * 1024;
} }
@ -558,8 +562,9 @@ void client_manager_init(void)
if (param) { if (param) {
long tmp = strtol(param->value, &test, 10); long tmp = strtol(param->value, &test, 10);
if (*test != '\0' || tmp <= 0) { if (*test != '\0' || tmp <= 0) {
FATAL("max output buffer size \"%s\" is not a positive " g_error("max output buffer size \"%s\" is not a positive "
"integer, line %i\n", param->value, param->line); "integer, line %i",
param->value, param->line);
} }
client_max_output_buffer_size = tmp * 1024; client_max_output_buffer_size = tmp * 1024;
} }
@ -587,13 +592,13 @@ void client_manager_expire(void)
list_for_each_entry_safe(client, n, &clients, siblings) { list_for_each_entry_safe(client, n, &clients, siblings) {
if (client_is_expired(client)) { if (client_is_expired(client)) {
DEBUG("client %i: expired\n", client->num); g_debug("client %i: expired", client->num);
client_close(client); client_close(client);
} else if (!client->idle_waiting && /* idle clients } else if (!client->idle_waiting && /* idle clients
never expire */ never expire */
time(NULL) - client->lastTime > time(NULL) - client->lastTime >
client_timeout) { client_timeout) {
DEBUG("client %i: timeout\n", client->num); g_debug("client %i: timeout", client->num);
client_close(client); client_close(client);
} }
} }
@ -632,13 +637,13 @@ static void client_write_deferred(struct client *client)
} }
if (g_queue_is_empty(client->deferred_send)) { if (g_queue_is_empty(client->deferred_send)) {
DEBUG("client %i: buffer empty %lu\n", client->num, g_debug("client %i: buffer empty %lu", client->num,
(unsigned long)client->deferred_bytes); (unsigned long)client->deferred_bytes);
assert(client->deferred_bytes == 0); assert(client->deferred_bytes == 0);
} else if (ret < 0 && errno != EAGAIN && errno != EINTR) { } else if (ret < 0 && errno != EAGAIN && errno != EINTR) {
/* cause client to close */ /* cause client to close */
DEBUG("client %i: problems flushing buffer\n", g_debug("client %i: problems flushing buffer",
client->num); client->num);
client_set_expired(client); client_set_expired(client);
} }
} }
@ -654,11 +659,11 @@ static void client_defer_output(struct client *client,
alloc = sizeof(*buf) - sizeof(buf->data) + length; alloc = sizeof(*buf) - sizeof(buf->data) + length;
client->deferred_bytes += alloc; client->deferred_bytes += alloc;
if (client->deferred_bytes > client_max_output_buffer_size) { if (client->deferred_bytes > client_max_output_buffer_size) {
ERROR("client %i: output buffer size (%lu) is " g_warning("client %i: output buffer size (%lu) is "
"larger than the max (%lu)\n", "larger than the max (%lu)",
client->num, client->num,
(unsigned long)client->deferred_bytes, (unsigned long)client->deferred_bytes,
(unsigned long)client_max_output_buffer_size); (unsigned long)client_max_output_buffer_size);
/* cause client to close */ /* cause client to close */
client_set_expired(client); client_set_expired(client);
return; return;
@ -683,7 +688,7 @@ static void client_write_direct(struct client *client,
if (errno == EAGAIN || errno == EINTR) { if (errno == EAGAIN || errno == EINTR) {
client_defer_output(client, data, length); client_defer_output(client, data, length);
} else { } else {
DEBUG("client %i: problems writing\n", client->num); g_debug("client %i: problems writing", client->num);
client_set_expired(client); client_set_expired(client);
return; return;
} }
@ -692,7 +697,7 @@ static void client_write_direct(struct client *client,
} }
if (!g_queue_is_empty(client->deferred_send)) if (!g_queue_is_empty(client->deferred_send))
DEBUG("client %i: buffer created\n", client->num); g_debug("client %i: buffer created", client->num);
} }
static void client_write_output(struct client *client) static void client_write_output(struct client *client)