ircd_config.c \
ircd_sock.c \
ircd_client.c \
+ ircd_parse.c \
+ ircd_auth.c \
+ ircd_users.c \
main.c
--- /dev/null
+/* ircd_auth.c - NextIRCd
+ * Copyright (C) 2012-2013 Philipp Kreil (pk910)
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation, either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ */
+#include "struct_auth.h"
+#include "struct_connection.h"
+#include "ircd_client.h"
+#include "IOHandler/IOSockets.h"
+#include "IOHandler/IODNSLookup.h"
+#include "version.h"
+
+static IODNS_CALLBACK(auth_dns_callback);
+
+static struct Auth *authlist_first = NULL;
+static struct Auth *authlist_last = NULL;
+
+struct Auth *auth_new(struct Connection *conn) {
+ struct Auth *auth = calloc(1, sizeof(*auth));
+ client_printf(conn, "NOTICE AUTH :*** NextIRCd v%d.%d (%s)", VERSION_NUMBER, patchlevel, revision);
+
+ auth->conn = conn;
+ time(&auth->startup_time);
+
+ auth->prev = authlist_last;
+ auth->next = NULL;
+ if(!authlist_last)
+ authlist_first = auth
+ authlist_last = auth;
+
+ return auth;
+}
+
+void auth_start_dnsreverse(struct Auth *auth) {
+ client_printf(auth->conn, "NOTICE AUTH :*** Looking up your hostname");
+
+ struct IODNSAddress *sockaddr;
+ sockaddr = iosocket_get_remote_addr(auth->conn->socket);
+ if(sockaddr) {
+ auth->dnslookup = iodns_getnameinfo(sockaddr->address, sockaddr->addresslen, auth_dns_callback, auth);
+ } else {
+ // critical error!
+ }
+}
+
+static IODNS_CALLBACK(auth_dns_callback) {
+ struct Auth *auth = event->query->data;
+ struct IODNSResult *dnsresult = event->result;
+
+ if(event->type == IODNSEVENT_SUCCESS) {
+ strncpy(auth->host, dnsresult->result.host, HOSTLEN);
+ client_printf(auth->conn, "NOTICE AUTH :*** Found your hostname (%s)", auth->host);
+ } else {
+ struct IODNSAddress *sockaddr = iosocket_get_remote_addr(auth->conn->socket);
+ if(sockaddr->addresslen == sizeof(struct sockaddr_in)) {
+ //ipv4
+ inet_ntop(AF_INET, (void *)(&((struct sockaddr_in *)sockaddr->address)->sin_addr), auth->host, HOSTLEN);
+ } else {
+ //ipv6
+ inet_ntop(AF_INET6, (void *)(&((struct sockaddr_in6 *)sockaddr->address)->sin6_addr), auth->host, HOSTLEN);
+ }
+ client_printf(auth->conn, "NOTICE AUTH :*** Couldn't look up your hostname. Using your IP instead (%s)", auth->host);
+ }
+ if(dnsresult)
+ iodns_free_result(dnsresult);
+
+ auth_try_finish(auth);
+}
+
+
+void auth_try_finish(struct Auth *auth) {
+
+}
--- /dev/null
+/* ircd_auth.h - NextIRCd
+ * Copyright (C) 2012-2013 Philipp Kreil (pk910)
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation, either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ */
+
+#ifndef _ircd_auth_h
+#define _ircd_auth_h
+
+struct Auth *auth_new(struct Connection *conn);
+void auth_start_dnsreverse(struct Auth *auth);
+void auth_try_finish(struct Auth *auth);
+
+#endif
#include "struct_connection.h"
#include "struct_auth.h"
#include "ircd_config.h"
-#include "version.h"
#include <stdio.h>
#include <stdlib.h>
#include <stdarg.h>
#define CLIENT_MAXLEN 512
-static void client_printf(struct Connection *conn, const char *text, ...) {
+void client_printf(struct Connection *conn, const char *text, ...) {
va_list arg_list;
char sendBuf[CLIENT_MAXLEN];
int pos;
}
void client_connected(struct Connection *conn) {
- client_printf(conn, "NOTICE AUTH :*** NextIRCd v%d.%d (%s)", VERSION_NUMBER, patchlevel, revision);
-
- struct Auth *auth = calloc(1, sizeof(*auth));
- auth->conn = conn;
- conn->data.auth = auth;
-
- /* maybe do some stuff here? */
+ struct Auth *auth = auth_new(conn);
+
+ auth_start_dnsreverse(auth);
}
void client_disconnected(struct Connection *conn) {
void client_disconnected(struct Connection *conn);
/* -- */
+void client_printf(struct Connection *conn, const char *text, ...);
#endif
+++ /dev/null
-/* ircd_nicks.c - NextIRCd
- * Copyright (C) 2012-2013 Philipp Kreil (pk910)
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-#include "struct_user.h"
-
-struct UserDictEntry {
- struct User *user;
- struct UserDict *next, *prev;
-};
-
-struct UserDict {
- struct UserDictEntry *users[65536]; // 2^16 (first 16 bit of nickhash as identifier)
-};
-
-
-
{NULL, 0, 1, 0} /* Server */
},
{{"NICK", "N"}, /* Nick Command */
- {cmd_nick_cli, 0, 1, 0}, /* Client */
- {cmd_nick_auth, 0, 1, 0}, /* Unauthed */
+ {cmd_nick_cli, 1, 1, 0}, /* Client */
+ {cmd_nick_auth, 1, 1, 0}, /* Unauthed */
{NULL, 0, 1, 0} /* Server */
},
{{"USER", "U"}, /* User Command */
#ifndef _struct_auth_h
#define _struct_auth_h
+#include "struct_user.h"
+#include <time.h>
+
+#define PASSLEN 50
+
+struct IODNSQuery;
struct Auth {
struct Connection *conn;
- char *nick;
- char *ident;
- char *realname;
- char *passwd;
-
- unsigned int ping_number;
+ char nick[NICKLEN+1];
+ char ident[IDENTLEN+1];
+ char realname[REALLEN+1];
+ char host[HOSTLEN+1];
+ char passwd[PASSLEN+1];
+
+ unsigned int ping_probe;
+ time_t startup_time;
+
+ struct IODNSQuery *dnslookup;
unsigned int server : 1;
unsigned int have_nick : 1;
unsigned int have_user : 1;
unsigned int have_pass : 1;
+ unsigned int have_dnsresolv : 1;
+ unsigned int have_pong : 1;
+
+ struct Auth *prev, *next;
};
#endif
#define _struct_user_h
#include "crypto_md5.h"
-#define NICKLEN 30
-#define IDENTLEN 15
-#define HOSTLEN 63
-#define REALLEN 50
+#define NICKLEN 30
+#define IDENTLEN 15
+#define HOSTLEN 63
+#define REALLEN 50
struct User {
unsigned int usernum;