index 5f368892c0970f89c14085172eb45e2bdf61fece..44247ebd4961988035b7c90c70baf12e377b8c0b 100644 (file)
#include <arpa/inet.h>
#include <fcntl.h>
+#include <sys/socket.h>
+#include <sys/un.h>
+
#include <stdlib.h>
#include <string.h>
#include <pthread.h>
+#include <netdb.h>
/*
* private variables
assert(conn && (conn->cmd != SDB_CONNECTION_IDLE));
assert(! conn->skip_len);
- sdb_log(SDB_LOG_DEBUG, "frontend: Handling command %u (len: %u)",
- conn->cmd, conn->cmd_len);
-
if (conn->cmd == SDB_CONNECTION_PING)
status = sdb_connection_ping(conn);
else if (conn->cmd == SDB_CONNECTION_STARTUP)
} /* sdb_connection_enable_logging */
sdb_conn_t *
-sdb_connection_accept(int fd)
+sdb_connection_accept(int fd, sdb_conn_setup_cb setup, void *user_data)
{
+ sdb_conn_t *conn;
+ const char *peer = "unknown";
+
if (fd < 0)
return NULL;
/* the placeholder will be replaced with the accepted file
* descriptor when initializing the object */
- return CONN(sdb_object_create(CONN_FD_PREFIX CONN_FD_PLACEHOLDER,
+ conn = CONN(sdb_object_create(CONN_FD_PREFIX CONN_FD_PLACEHOLDER,
connection_type, fd));
+ if (setup && (setup(conn, user_data) < 0)) {
+ sdb_object_deref(SDB_OBJ(conn));
+ return NULL;
+ }
+
+ if (conn->username)
+ peer = conn->username;
+
+ if (conn->client_addr.ss_family == AF_UNIX) {
+ sdb_log(SDB_LOG_INFO,
+ "frontend: Accepted connection from peer %s", peer);
+ }
+ else {
+ char host[1024] = "<unknown>", port[32] = "";
+ getnameinfo((struct sockaddr *)&conn->client_addr,
+ conn->client_addr_len, host, sizeof(host), port, sizeof(port),
+ NI_NUMERICHOST | NI_NUMERICSERV);
+ sdb_log(SDB_LOG_INFO, "frontend: Accepted connection from "
+ "peer %s at %s:%s", peer, host, port);
+ }
+ return conn;
} /* sdb_connection_create */
void