#include "UserNode.h"
#include "ChanUser.h"
+#include "mysqlConn.h"
+#include "lang.h"
static struct UserNode **userList;
void init_UserNode() {
- userList = calloc(VALID_NICK_CHARS_FIRST_LEN, sizeof(*userList));
-
+ userList = calloc(VALID_NICK_CHARS_FIRST_LEN+1, sizeof(*userList));
+}
+
+void free_UserNode() {
+ //kamikaze free all users
+ //chanusers will be destroyed in free_ChanNode()
+ int i;
+ struct UserNode *user, *next;
+ for(i = 0; i < VALID_NICK_CHARS_FIRST_LEN+1; i++) {
+ for(user = userList[i]; user; user = next) {
+ next = user->next;
+ free(user);
+ }
+ }
+ free(userList);
}
int is_valid_nick(const char *nick) {
return NULL;
}
strcpy(user->nick, nick);
+ user->created = time(0);
user->ident[0] = 0;
user->host[0] = 0;
user->realname[0] = 0;
for(i = 0; i < strlen(mask)+1; i++) {
if(cmask[i] == '!') {
cmask[i] = 0;
- struct UserNode *user = malloc(sizeof(*user));
+ user = malloc(sizeof(*user));
if (!user)
{
perror("malloc() failed");
return NULL;
}
- strcpy(user->nick, nick);
+ strcpy(user->nick, cmask);
+ user->created = time(0);
user->ident[0] = 0;
user->host[0] = 0;
user->realname[0] = 0;
ii = i+1;
} else if(cmask[i] == '.' && !user) {
//it's a server
- struct UserNode *user = malloc(sizeof(*user));
+ user = malloc(sizeof(*user));
if (!user)
{
perror("malloc() failed");
return NULL;
}
strcpy(user->host, cmask);
+ user->created = time(0);
user->ident[0] = 0;
user->host[0] = 0;
user->realname[0] = 0;
else
user->next = NULL;
}
+
+void clearTempUsers() {
+ int userListIndex = TEMPUSER_LIST_INDEX;
+ struct UserNode *cuser, *last_user = NULL, *next;
+ time_t now = time(0);
+ for(cuser = userList[userListIndex]; cuser; cuser = next) {
+ next = cuser->next;
+ if(cuser->flags & USERFLAG_FREETMPUSER || now - cuser->created >= 300) {
+ if(last_user)
+ last_user->next = cuser->next;
+ else
+ userList[userListIndex] = cuser->next;
+ break;
+ } else
+ last_user = cuser;
+ }
+}
+
+
+void load_user_settings(struct UserNode *user) {
+ if(!(user->flags & USERFLAG_ISAUTHED) || (user->flags & USERFLAG_LOADED_SETTINGS))
+ return;
+ check_mysql();
+ MYSQL_RES *res;
+ MYSQL_ROW row;
+ printf_mysql_query("SELECT `user_lang`, `user_reply_privmsg`, `user_god` FROM `users` WHERE `user_user` = '%s'", escape_string(user->auth));
+ res = mysql_use();
+ if ((row = mysql_fetch_row(res)) != NULL) {
+ user->language = get_language_by_tag(row[0]);
+ if(user->language == NULL) user->language = get_default_language();
+ if(strcmp(row[1], "0"))
+ user->flags |= USERFLAG_REPLY_PRIVMSG;
+ if(strcmp(row[2], "0"))
+ user->flags |= USERFLAG_GOD_MODE;
+ } else
+ user->language = get_default_language();
+ user->flags |= USERFLAG_LOADED_SETTINGS;
+}
+
+int isGodMode(struct UserNode *user) {
+ load_user_settings(user);
+ return (user->flags & USERFLAG_GOD_MODE);
+}