X-Git-Url: http://git.pk910.de/?a=blobdiff_plain;f=src%2FDBHelper.c;fp=src%2FDBHelper.c;h=4f3dd757262d0150e93a3966731b163d6712ee92;hb=55831bf424312a6908ca07a904f288fba0919a9a;hp=cf7105b13e4450c715033a985abf702405edad8b;hpb=0dfad39f7dacc3ca67298c9aecb5a7f8eec75fdc;p=NeonServV5.git diff --git a/src/DBHelper.c b/src/DBHelper.c index cf7105b..4f3dd75 100644 --- a/src/DBHelper.c +++ b/src/DBHelper.c @@ -26,6 +26,7 @@ #include "HandleInfoHandler.h" void _loadUserSettings(struct UserNode *user) { + SYNCHRONIZE(cache_sync); MYSQL_RES *res; MYSQL_ROW row; printf_mysql_query("SELECT `user_lang`, `user_reply_privmsg`, `user_god`, `user_id` FROM `users` WHERE `user_user` = '%s'", escape_string(user->auth)); @@ -42,6 +43,7 @@ void _loadUserSettings(struct UserNode *user) { } else user->language = get_default_language(); user->flags |= USERFLAG_LOADED_SETTINGS; + DESYNCHRONIZE(cache_sync); } int isGodMode(struct UserNode *user) { @@ -129,6 +131,7 @@ int checkChannelAccess(struct UserNode *user, struct ChanNode *chan, char *chann } void _loadChannelSettings(struct ChanNode *chan) { + SYNCHRONIZE(cache_sync); MYSQL_RES *res; MYSQL_ROW row; printf_mysql_query("SELECT `channel_id` FROM `channels` WHERE `channel_name` = '%s'", escape_string(chan->name)); @@ -138,6 +141,7 @@ void _loadChannelSettings(struct ChanNode *chan) { chan->channel_id = atoi(row[0]); } chan->flags |= CHANFLAG_REQUESTED_CHANINFO; + DESYNCHRONIZE(cache_sync); } //TODO: fix performance: we should cache the user access