X-Git-Url: http://git.pk910.de/?a=blobdiff_plain;f=DBHelper.c;h=181fff607b542c6262721a4fe973414594ec5d8c;hb=795115bf680185ae01043bd1222b78bfed8c1d87;hp=c8efb6b12092c13715b11aafdf8f36d894d808e2;hpb=fb1dee61840455a6669c868f30701e963cdfa629;p=NeonServV5.git diff --git a/DBHelper.c b/DBHelper.c index c8efb6b..181fff6 100644 --- a/DBHelper.c +++ b/DBHelper.c @@ -5,10 +5,9 @@ #include "ChanUser.h" #include "mysqlConn.h" #include "lang.h" - +#include "tools.h" void _loadUserSettings(struct UserNode *user) { - 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)); @@ -36,7 +35,6 @@ int getChannelAccess(struct UserNode *user, struct ChanNode *chan, int override) if(!(chan->flags & CHANFLAG_CHAN_REGISTERED)) return 0; MYSQL_RES *res; MYSQL_ROW row; - check_mysql(); int caccess = 0; printf_mysql_query("SELECT `user_id`, `user_access`, `user_god` FROM `users` WHERE `user_user` = '%s'", escape_string(user->auth)); res = mysql_use(); @@ -95,7 +93,6 @@ int checkChannelAccess(struct UserNode *user, struct ChanNode *chan, char *chann } void _loadChannelSettings(struct ChanNode *chan) { - check_mysql(); MYSQL_RES *res; MYSQL_ROW row; printf_mysql_query("SELECT `channel_id` FROM `channels` WHERE `channel_name` = '%s'", escape_string(chan->name)); @@ -154,4 +151,16 @@ int isUserProtected(struct ChanNode *chan, struct UserNode *victim, struct UserN return 0; } - +char *getBanAffectingMask(struct ChanNode *chan, char *mask) { + loadChannelSettings(chan); + if(!(chan->flags & CHANFLAG_CHAN_REGISTERED)) return 0; + MYSQL_RES *res; + MYSQL_ROW row; + printf_mysql_query("SELECT `ban_mask` FROM `bans` WHERE `ban_channel` = '%d'", chan->channel_id); + res = mysql_use(); + while ((row = mysql_fetch_row(res)) != NULL) { + if(!match(row[0], mask)) + return row[0]; + } + return NULL; +}