2 struct neonserv_event_join_cache {
3 struct ClientSocket *client;
4 struct ChanUser *chanuser;
7 static USERAUTH_CALLBACK(neonserv_event_join_nick_lookup);
8 static void neonserv_event_join_async1(struct ClientSocket *client, struct ChanUser *chanuser);
10 static void neonserv_event_join(struct ChanUser *chanuser) {
11 struct UserNode *user = chanuser->user;
12 struct ClientSocket *client = getBotForChannel(chanuser->chan);
13 if(!client) return; //we can't "see" this event
14 if(user->flags & USERFLAG_ISBOT) {
15 putsock(client, "MODE %s +o %s", chanuser->chan->name, chanuser->user->nick);
18 loadChannelSettings(chanuser->chan);
19 if(!(chanuser->chan->flags & CHANFLAG_CHAN_REGISTERED)) return;
21 char usermask[NICKLEN+USERLEN+HOSTLEN+3];
22 sprintf(usermask, "%s!%s@%s", user->nick, user->ident, user->host);
23 if((ban = getBanAffectingMask(chanuser->chan, usermask)) != NULL && !(user->flags & (USERFLAG_ISBOT | USERFLAG_ISIRCOP))) {
26 printf_mysql_query("SELECT `ban_reason`, `user_user` FROM `bans` LEFT JOIN `users` ON `ban_owner` = `user_id` WHERE `ban_channel` = '%d' AND `ban_mask` = '%s'", chanuser->chan->channel_id, escape_string(ban));
28 if ((row = mysql_fetch_row(res)) != NULL) {
29 putsock(client, "MODE %s +b %s", chanuser->chan->name, ban);
30 putsock(client, "KICK %s %s :(%s) %s", chanuser->chan->name, chanuser->user->nick, row[1], row[0]);
34 if(!(user->flags & USERFLAG_ISAUTHED)) {
35 struct neonserv_event_join_cache *cache = malloc(sizeof(*cache));
37 perror("malloc() failed");
40 cache->client = client;
41 cache->chanuser = chanuser;
42 get_userauth(user, neonserv_event_join_nick_lookup, cache);
44 neonserv_event_join_async1(client, chanuser);
47 static USERAUTH_CALLBACK(neonserv_event_join_nick_lookup) {
48 struct neonserv_event_join_cache *cache = data;
50 neonserv_event_join_async1(cache->client, cache->chanuser);
55 static void neonserv_event_join_async1(struct ClientSocket *client, struct ChanUser *chanuser) {
56 struct ClientSocket *textclient = ((client->flags & SOCKET_FLAG_PREFERRED) ? client : get_prefered_bot(client->botid));
57 struct ChanNode *chan = chanuser->chan;
58 struct UserNode *user = chanuser->user;
60 MYSQL_ROW row, chanuserrow;
61 printf_mysql_query("SELECT `channel_maxusers`, `channel_greeting`, `channel_usergreeting` FROM `channels` WHERE `channel_id` = '%d'", chan->channel_id);
63 if ((row = mysql_fetch_row(res)) == NULL) return;
64 if(chan->usercount > atoi(row[0])) {
66 printf_mysql_query("UPDATE `channels` SET `channel_maxusers` = '%d' WHERE `channel_id` = '%d'", chan->usercount, chan->channel_id);
68 printf_mysql_query("SELECT `chanuser_access`, `chanuser_flags`, `chanuser_info` FROM `channels` WHERE `channel_id` = '%d'", chan->channel_id);
70 chanuserrow = mysql_fetch_row(res);
71 int userflags = (chanuserrow ? atoi(chanuserrow[1]) : 0);
72 int uaccess = ((chanuserrow && !(userflags & DB_CHANUSER_SUSPENDED)) ? atoi(chanuserrow[0]) : 0);
74 char greeting[MAXLEN];
76 char *a, *b = (chanuserrow ? row[2] : row[1]);
81 greetingPos += sprintf(greeting + greetingPos, "%s", b);
88 greetingPos += sprintf(greeting + greetingPos, "%d", uaccess);
91 greetingPos += sprintf(greeting + greetingPos, "%s", client->user->nick);
94 greetingPos += sprintf(greeting + greetingPos, "%s", user->nick);
97 greetingPos += sprintf(greeting + greetingPos, "%s@%s", user->ident, user->host);
100 greetingPos += sprintf(greeting + greetingPos, "%s", ((user->flags & USERFLAG_ISAUTHED) ? user->auth : "*"));
103 greeting[greetingPos++] = '$';
104 greeting[greetingPos++] = a[1];
111 reply(textclient, user, "[%s] %s", chan->name, greeting);