/* * Copyright (c) 2003-2005 by FlashCode * See README for License detail, AUTHORS for developers list. * * 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 2 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, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */ /* irc-recv.c: implementation of IRC commands (server to client), according to RFC 1459,2810,2811,2812 */ #ifdef HAVE_CONFIG_H #include "config.h" #endif #include #include #include #include #include #include #include #include "../common/weechat.h" #include "irc.h" #include "../common/command.h" #include "../common/hotlist.h" #include "../common/weeconfig.h" #include "../gui/gui.h" #include "../plugins/plugins.h" /* * irc_recv_command: executes action when receiving IRC command * returns: 0 = all ok, command executed * -1 = command failed * -2 = no command to execute * -3 = command not found */ int irc_recv_command (t_irc_server *server, char *entire_line, char *host, char *command, char *arguments) { int i, cmd_found, return_code; if (command == NULL) return -2; /* look for IRC command */ cmd_found = -1; for (i = 0; irc_commands[i].command_name; i++) { if (strcasecmp (irc_commands[i].command_name, command) == 0) { cmd_found = i; break; } } /* command not found */ if (cmd_found < 0) return -3; if (irc_commands[i].recv_function != NULL) { return_code = (int) (irc_commands[i].recv_function) (server, host, arguments); plugin_event_msg (irc_commands[i].command_name, server->name, entire_line); return return_code; } return 0; } /* * irc_cmd_recv_error: error received from server */ int irc_cmd_recv_error (t_irc_server *server, char *host, char *arguments) { char *pos, *pos2; int first; t_gui_buffer *ptr_buffer; t_irc_channel *ptr_channel; /* make gcc happy */ (void) server; (void) host; if (strncmp (arguments, "Closing Link", 12) == 0) { server_disconnect (server, 1); return 0; } pos = strchr (arguments, ' '); if (pos) { pos[0] = '\0'; pos++; while (pos[0] == ' ') pos++; } else pos = arguments; first = 1; ptr_buffer = server->buffer; while (pos && pos[0]) { pos2 = strchr (pos, ' '); if ((pos[0] == ':') || (!pos2)) { if (pos[0] == ':') pos++; if (first) irc_display_prefix (ptr_buffer, PREFIX_ERROR); gui_printf_color (ptr_buffer, COLOR_WIN_CHAT, "%s%s\n", (first) ? "" : ": ", pos); pos = NULL; } else { pos2[0] = '\0'; if (first) { ptr_channel = channel_search (server, pos); if (ptr_channel) ptr_buffer = ptr_channel->buffer; irc_display_prefix (ptr_buffer, PREFIX_ERROR); } gui_printf_color (ptr_buffer, COLOR_WIN_CHAT_CHANNEL, "%s%s", (first) ? "" : " ", pos); first = 0; pos = pos2 + 1; } } return 0; } /* * irc_cmd_recv_invite: 'invite' message received */ int irc_cmd_recv_invite (t_irc_server *server, char *host, char *arguments) { char *pos, *pos_channel; pos = strchr (host, '!'); if (pos) pos[0] = '\0'; pos_channel = strchr (arguments, ' '); if (pos_channel) { pos_channel[0] = '\0'; pos_channel++; while (pos_channel[0] == ' ') pos_channel++; if (pos_channel[0] == ':') pos_channel++; irc_display_prefix (server->buffer, PREFIX_SERVER); gui_printf (server->buffer, _("You have been invited to ")); gui_printf_color (server->buffer, COLOR_WIN_CHAT_CHANNEL, "%s ", pos_channel); gui_printf (server->buffer, _("by")); gui_printf_color (server->buffer, COLOR_WIN_CHAT_NICK, " %s\n", host); hotlist_add (2, server->buffer); gui_draw_buffer_status (gui_current_window->buffer, 1); } else { irc_display_prefix (server->buffer, PREFIX_ERROR); gui_printf_nolog (server->buffer, _("%s channel \"%s\" not found for \"%s\" command\n"), WEECHAT_ERROR, "", "invite"); return -1; } return 0; } /* * irc_cmd_recv_join: 'join' message received */ int irc_cmd_recv_join (t_irc_server *server, char *host, char *arguments) { t_irc_channel *ptr_channel; char *pos; ptr_channel = channel_search (server, arguments); if (!ptr_channel) { ptr_channel = channel_new (server, CHAT_CHANNEL, arguments, 1); if (!ptr_channel) { irc_display_prefix (server->buffer, PREFIX_ERROR); gui_printf_nolog (server->buffer, _("%s cannot create new channel \"%s\"\n"), WEECHAT_ERROR, arguments); return -1; } } pos = strchr (host, '!'); if (pos) pos[0] = '\0'; irc_display_prefix (ptr_channel->buffer, PREFIX_JOIN); gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT_NICK, "%s ", host); gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT_DARK, "("); gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT_HOST, "%s", pos + 1); gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT_DARK, ")"); gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT, _(" has joined ")); gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT_CHANNEL, "%s\n", arguments); (void) nick_new (ptr_channel, host, 0, 0, 0, 0, 0); gui_draw_buffer_nick (ptr_channel->buffer, 1); gui_draw_buffer_status (ptr_channel->buffer, 1); return 0; } /* * irc_cmd_recv_kick: 'kick' message received */ int irc_cmd_recv_kick (t_irc_server *server, char *host, char *arguments) { char *pos, *pos_nick, *pos_comment; t_irc_channel *ptr_channel; t_irc_nick *ptr_nick; pos = strchr (host, '!'); if (pos) pos[0] = '\0'; pos_nick = strchr (arguments, ' '); if (pos_nick) { pos_nick[0] = '\0'; pos_nick++; while (pos_nick[0] == ' ') pos_nick++; pos_comment = strchr (pos_nick, ' '); if (pos_comment) { pos_comment[0] = '\0'; pos_comment++; while (pos_comment[0] == ' ') pos_comment++; if (pos_comment[0] == ':') pos_comment++; } ptr_channel = channel_search (server, arguments); if (!ptr_channel) { irc_display_prefix (server->buffer, PREFIX_ERROR); gui_printf_nolog (server->buffer, _("%s channel \"%s\" not found for \"%s\" command\n"), WEECHAT_ERROR, arguments, "kick"); return -1; } irc_display_prefix (ptr_channel->buffer, PREFIX_PART); gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT_NICK, "%s", host); gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT, _(" has kicked ")); gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT_NICK, "%s", pos_nick); gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT, _(" from ")); if (pos_comment) { gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT_CHANNEL, "%s ", arguments); gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT_DARK, "("); gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT, "%s", pos_comment); gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT_DARK, ")\n"); } else gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT_CHANNEL, "%s\n", arguments); } else { irc_display_prefix (server->buffer, PREFIX_ERROR); gui_printf_nolog (server->buffer, _("%s nick \"%s\" not found for \"%s\" command\n"), WEECHAT_ERROR, "", "kick"); return -1; } if (strcmp (pos_nick, server->nick) == 0) { /* my nick was kicked => free all nicks, channel is not active any more */ nick_free_all (ptr_channel); gui_draw_buffer_nick (ptr_channel->buffer, 1); gui_draw_buffer_status (ptr_channel->buffer, 1); if (server->autorejoin) irc_cmd_send_join (server, ptr_channel->name); } { /* someone was kicked from channel (but not me) => remove only this nick */ ptr_nick = nick_search (ptr_channel, pos_nick); if (ptr_nick) { nick_free (ptr_channel, ptr_nick); gui_draw_buffer_nick (ptr_channel->buffer, 1); gui_draw_buffer_status (ptr_channel->buffer, 1); } } return 0; } /* * irc_get_channel_modes: get channel modes */ void irc_get_channel_modes (t_irc_channel *ptr_channel, char *channel_name, char *nick_host, char *modes, char *parm) { char *pos, set_flag; t_irc_nick *ptr_nick; set_flag = '+'; while (modes && modes[0]) { switch (modes[0]) { case '+': set_flag = '+'; break; case '-': set_flag = '-'; break; case 'b': pos = NULL; if (parm) { pos = strchr (parm, ' '); if (pos) pos[0] = '\0'; } if (nick_host) irc_display_mode (ptr_channel->buffer, channel_name, set_flag, "b", nick_host, (set_flag == '+') ? _("sets ban on") : _("removes ban on"), (parm) ? parm : NULL); /* look for next parameter */ if (parm && pos) { pos++; while (pos[0] == ' ') pos++; parm = pos; } break; case 'h': pos = NULL; if (parm) { pos = strchr (parm, ' '); if (pos) pos[0] = '\0'; } if (nick_host) irc_display_mode (ptr_channel->buffer, channel_name, set_flag, "h", nick_host, (set_flag == '+') ? _("gives half channel operator status to") : _("removes half channel operator status from"), (parm) ? parm : NULL); if (parm) { ptr_nick = nick_search (ptr_channel, parm); if (ptr_nick) { ptr_nick->is_halfop = (set_flag == '+') ? 1 : 0; nick_resort (ptr_channel, ptr_nick); gui_draw_buffer_nick (ptr_channel->buffer, 1); } } /* look for next parameter */ if (parm && pos) { pos++; while (pos[0] == ' ') pos++; parm = pos; } break; case 'i': if (nick_host) irc_display_mode (ptr_channel->buffer, channel_name, set_flag, "i", nick_host, (set_flag == '+') ? _("sets invite-only channel flag") : _("removes invite-only channel flag"), NULL); SET_CHANNEL_MODE(ptr_channel, (set_flag == '+'), CHANNEL_MODE_INVITE); break; case 'k': pos = NULL; if (parm) { pos = strchr (parm, ' '); if (pos) pos[0] = '\0'; } if (nick_host) irc_display_mode (ptr_channel->buffer, channel_name, set_flag, "k", nick_host, (set_flag == '+') ? _("sets channel key to") : _("removes channel key"), (set_flag == '+') ? ((parm) ? parm : NULL) : NULL); SET_CHANNEL_MODE(ptr_channel, (set_flag == '+'), CHANNEL_MODE_KEY); if (ptr_channel->key) free (ptr_channel->key); ptr_channel->key = strdup (parm); /* look for next parameter */ if (parm && pos) { pos++; while (pos[0] == ' ') pos++; parm = pos; } break; case 'l': pos = NULL; if (parm) { pos = strchr (parm, ' '); if (pos) pos[0] = '\0'; } if (nick_host) irc_display_mode (ptr_channel->buffer, channel_name, set_flag, "l", nick_host, (set_flag == '+') ? _("sets the user limit to") : _("removes user limit"), (set_flag == '+') ? ((parm) ? parm : NULL) : NULL); SET_CHANNEL_MODE(ptr_channel, (set_flag == '+'), CHANNEL_MODE_LIMIT); ptr_channel->limit = atoi (parm); /* look for next parameter */ if (parm && pos) { pos++; while (pos[0] == ' ') pos++; parm = pos; } break; case 'm': if (nick_host) irc_display_mode (ptr_channel->buffer, channel_name, set_flag, "m", nick_host, (set_flag == '+') ? _("sets moderated channel flag") : _("removes moderated channel flag"), NULL); SET_CHANNEL_MODE(ptr_channel, (set_flag == '+'), CHANNEL_MODE_MODERATED); break; case 'n': if (nick_host) irc_display_mode (ptr_channel->buffer, channel_name, set_flag, "n", nick_host, (set_flag == '+') ? _("sets messages from channel only flag") : _("removes messages from channel only flag"), NULL); SET_CHANNEL_MODE(ptr_channel, (set_flag == '+'), CHANNEL_MODE_NO_MSG_OUT); break; case 'o': pos = NULL; if (parm) { pos = strchr (parm, ' '); if (pos) pos[0] = '\0'; } if (nick_host) irc_display_mode (ptr_channel->buffer, channel_name, set_flag, "o", nick_host, (set_flag == '+') ? _("gives channel operator status to") : _("removes channel operator status from"), (parm) ? parm : NULL); if (parm) { ptr_nick = nick_search (ptr_channel, parm); if (ptr_nick) { ptr_nick->is_op = (set_flag == '+') ? 1 : 0; nick_resort (ptr_channel, ptr_nick); gui_draw_buffer_nick (ptr_channel->buffer, 1); } } /* look for next parameter */ if (parm && pos) { pos++; while (pos[0] == ' ') pos++; parm = pos; } break; case 'p': if (nick_host) irc_display_mode (ptr_channel->buffer, channel_name, set_flag, "p", nick_host, (set_flag == '+') ? _("sets private channel flag") : _("removes private channel flag"), NULL); SET_CHANNEL_MODE(ptr_channel, (set_flag == '+'), CHANNEL_MODE_SECRET); break; case 's': if (nick_host) irc_display_mode (ptr_channel->buffer, channel_name, set_flag, "s", nick_host, (set_flag == '+') ? _("sets secret channel flag") : _("removes secret channel flag"), NULL); SET_CHANNEL_MODE(ptr_channel, (set_flag == '+'), CHANNEL_MODE_SECRET); break; case 't': if (nick_host) irc_display_mode (ptr_channel->buffer, channel_name, set_flag, "t", nick_host, (set_flag == '+') ? _("sets topic protection") : _("removes topic protection"), NULL); SET_CHANNEL_MODE(ptr_channel, (set_flag == '+'), CHANNEL_MODE_TOPIC); break; case 'v': pos = NULL; if (parm) { pos = strchr (parm, ' '); if (pos) pos[0] = '\0'; } if (nick_host) irc_display_mode (ptr_channel->buffer, channel_name, set_flag, "v", nick_host, (set_flag == '+') ? _("gives voice to") : _("removes voice from"), (parm) ? parm : NULL); if (parm) { ptr_nick = nick_search (ptr_channel, parm); if (ptr_nick) { ptr_nick->has_voice = (set_flag == '+') ? 1 : 0; nick_resort (ptr_channel, ptr_nick); gui_draw_buffer_nick (ptr_channel->buffer, 1); } } /* look for next parameter */ if (parm && pos) { pos++; while (pos[0] == ' ') pos++; parm = pos; } break; } modes++; } } /* * irc_cmd_recv_mode: 'mode' message received */ int irc_cmd_recv_mode (t_irc_server *server, char *host, char *arguments) { char *pos, *pos_parm; t_irc_channel *ptr_channel; /* no host => we can't identify sender of message! */ if (host == NULL) { irc_display_prefix (server->buffer, PREFIX_ERROR); gui_printf_nolog (server->buffer, _("%s \"%s\" command received without host\n"), WEECHAT_ERROR, "mode"); return -1; } /* keep only nick name from host */ pos = strchr (host, '!'); if (pos) pos[0] = '\0'; pos = strchr (arguments, ' '); if (!pos) { irc_display_prefix (server->buffer, PREFIX_ERROR); gui_printf_nolog (server->buffer, _("%s \"%s\" command received without channel or nickname\n"), WEECHAT_ERROR, "mode"); return -1; } pos[0] = '\0'; pos++; while (pos[0] == ' ') pos++; pos_parm = strchr (pos, ' '); if (pos_parm) { pos_parm[0] = '\0'; pos_parm++; while (pos_parm[0] == ' ') pos_parm++; } if (string_is_channel (arguments)) { ptr_channel = channel_search (server, arguments); if (ptr_channel) { irc_get_channel_modes (ptr_channel, arguments, host, pos, pos_parm); gui_draw_buffer_status (ptr_channel->buffer, 0); } else { irc_display_prefix (server->buffer, PREFIX_ERROR); gui_printf_nolog (server->buffer, _("%s channel \"%s\" not found for \"%s\" command\n"), WEECHAT_ERROR, arguments, "mode"); return -1; } } else { /* nickname modes */ irc_display_prefix (server->buffer, PREFIX_SERVER); gui_printf_color (server->buffer, COLOR_WIN_CHAT_DARK, "["); gui_printf_color (server->buffer, COLOR_WIN_CHAT_NICK, "%s", arguments); gui_printf_color (server->buffer, COLOR_WIN_CHAT, "/"); gui_printf_color (server->buffer, COLOR_WIN_CHAT_NICK, "%s", (pos[0] == ':') ? pos + 1 : pos); gui_printf_color (server->buffer, COLOR_WIN_CHAT_DARK, "] "); gui_printf_color (server->buffer, COLOR_WIN_CHAT, _("mode changed by")); gui_printf_color (server->buffer, COLOR_WIN_CHAT_NICK, " %s\n", host); } return 0; } /* * irc_cmd_recv_nick: 'nick' message received */ int irc_cmd_recv_nick (t_irc_server *server, char *host, char *arguments) { char *pos; t_irc_channel *ptr_channel; t_irc_nick *ptr_nick; int nick_is_me; t_gui_window *ptr_win; t_gui_buffer *ptr_buffer; /* no host => we can't identify sender of message! */ if (host == NULL) { irc_display_prefix (server->buffer, PREFIX_ERROR); gui_printf_nolog (server->buffer, _("%s \"%s\" command received without host\n"), WEECHAT_ERROR, "nick"); return -1; } /* keep only nick name from host */ pos = strchr (host, '!'); if (pos) pos[0] = '\0'; /* change nickname in any opened private window */ for (ptr_buffer = gui_buffers; ptr_buffer; ptr_buffer = ptr_buffer->next_buffer) { if ((SERVER(ptr_buffer) == server) && BUFFER_IS_PRIVATE(ptr_buffer)) { if ((CHANNEL(ptr_buffer)->name) && (strcasecmp (host, CHANNEL(ptr_buffer)->name) == 0)) { free (CHANNEL(ptr_buffer)->name); CHANNEL(ptr_buffer)->name = strdup (arguments); } } } for (ptr_channel = server->channels; ptr_channel; ptr_channel = ptr_channel->next_channel) { ptr_nick = nick_search (ptr_channel, host); if (ptr_nick) { nick_is_me = (strcmp (ptr_nick->nick, server->nick) == 0) ? 1 : 0; if (nick_is_me) gui_add_hotlist = 0; nick_change (ptr_channel, ptr_nick, arguments); irc_display_prefix (ptr_channel->buffer, PREFIX_INFO); if (nick_is_me) gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT, _("You are ")); else { gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT_NICK, "%s", host); gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT, _(" is ")); } gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT, _("now known as ")); gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT_NICK, "%s\n", arguments); if (gui_buffer_has_nicklist (ptr_channel->buffer)) gui_draw_buffer_nick (ptr_channel->buffer, 1); gui_add_hotlist = 1; } } if (strcmp (server->nick, host) == 0) { free (server->nick); server->nick = strdup (arguments); gui_draw_buffer_status (gui_current_window->buffer, 1); for (ptr_win = gui_windows; ptr_win; ptr_win = ptr_win->next_window) { if (ptr_win->buffer->server == server) gui_draw_buffer_input (ptr_win->buffer, 1); } } else { gui_draw_buffer_status (gui_current_window->buffer, 1); gui_draw_buffer_input (gui_current_window->buffer, 1); } return 0; } /* * irc_cmd_recv_notice: 'notice' message received */ int irc_cmd_recv_notice (t_irc_server *server, char *host, char *arguments) { char *host2, *pos, *pos2, *pos_usec; struct timeval tv; struct timezone tz; long sec1, usec1, sec2, usec2, difftime; host2 = NULL; if (host) { pos = strchr (host, '!'); if (pos) { pos[0] = '\0'; host2 = pos + 1; } else host2 = NULL; } pos = strchr (arguments, ' '); if (pos) { pos[0] = '\0'; pos++; while (pos[0] == ' ') pos++; if (pos[0] == ':') pos++; } else { irc_display_prefix (server->buffer, PREFIX_ERROR); gui_printf_nolog (server->buffer, _("%s nickname not found for \"%s\" command\n"), WEECHAT_ERROR, "notice"); return -1; } if (strncmp (pos, "\01VERSION", 8) == 0) { pos += 9; pos2 = strchr (pos, '\01'); if (pos2) pos2[0] = '\0'; irc_display_prefix (server->buffer, PREFIX_SERVER); gui_printf_color (server->buffer, COLOR_WIN_CHAT, "CTCP "); gui_printf_color (server->buffer, COLOR_WIN_CHAT_CHANNEL, "VERSION "); gui_printf_color (server->buffer, COLOR_WIN_CHAT, _("reply from")); gui_printf_color (server->buffer, COLOR_WIN_CHAT_NICK, " %s", host); gui_printf_color (server->buffer, COLOR_WIN_CHAT, ": %s\n", pos); } else { if (strncmp (pos, "\01PING", 5) == 0) { pos += 5; while (pos[0] == ' ') pos++; pos_usec = strchr (pos, ' '); if (pos_usec) { pos_usec[0] = '\0'; pos_usec++; pos2 = strchr (pos_usec, '\01'); if (pos2) { pos2[0] = '\0'; gettimeofday (&tv, &tz); sec1 = atol (pos); usec1 = atol (pos_usec); sec2 = tv.tv_sec; usec2 = tv.tv_usec; difftime = ((sec2 * 1000000) + usec2) - ((sec1 * 1000000) + usec1); irc_display_prefix (server->buffer, PREFIX_SERVER); gui_printf_color (server->buffer, COLOR_WIN_CHAT, "CTCP "); gui_printf_color (server->buffer, COLOR_WIN_CHAT_CHANNEL, "PING "); gui_printf_color (server->buffer, COLOR_WIN_CHAT, _("reply from")); gui_printf_color (server->buffer, COLOR_WIN_CHAT_NICK, " %s", host); gui_printf_color (server->buffer, COLOR_WIN_CHAT, _(": %ld.%ld seconds\n"), difftime / 1000000, (difftime % 1000000) / 1000); } } } else { irc_display_prefix (server->buffer, PREFIX_SERVER); if (host) { gui_printf_color (server->buffer, COLOR_WIN_CHAT_NICK, "%s", host); if (host2) { gui_printf_color (server->buffer, COLOR_WIN_CHAT_DARK, " ("); gui_printf_color (server->buffer, COLOR_WIN_CHAT_HOST, "%s", host2); gui_printf_color (server->buffer, COLOR_WIN_CHAT_DARK, ")"); } gui_printf_color (server->buffer, COLOR_WIN_CHAT, ": "); } gui_printf_color (server->buffer, COLOR_WIN_CHAT, "%s\n", pos); if ((host) && (strcasecmp (host, "nickserv") != 0) && (strcasecmp (host, "chanserv") != 0) && (strcasecmp (host, "memoserv") != 0)) { hotlist_add (2, server->buffer); gui_draw_buffer_status (gui_current_window->buffer, 1); } } } return 0; } /* * irc_cmd_recv_part: 'part' message received */ int irc_cmd_recv_part (t_irc_server *server, char *host, char *arguments) { char *pos, *pos_args; t_irc_channel *ptr_channel; t_irc_nick *ptr_nick; /* no host => we can't identify sender of message! */ if (!host || !arguments) { irc_display_prefix (server->buffer, PREFIX_ERROR); gui_printf_nolog (server->buffer, _("%s \"%s\" command received without host or channel\n"), WEECHAT_ERROR, "part"); return -1; } pos_args = strchr (arguments, ' '); if (pos_args) { pos_args[0] = '\0'; pos_args++; while (pos_args[0] == ' ') pos_args++; if (pos_args[0] == ':') pos_args++; } /* keep only nick name from host */ pos = strchr (host, '!'); if (pos) pos[0] = '\0'; ptr_channel = channel_search (server, arguments); if (ptr_channel) { ptr_nick = nick_search (ptr_channel, host); if (ptr_nick) { if (strcmp (ptr_nick->nick, server->nick) == 0) { /* part request was issued by local client */ gui_buffer_free (ptr_channel->buffer, 1); channel_free (server, ptr_channel); gui_draw_buffer_status (gui_current_window->buffer, 1); gui_draw_buffer_input (gui_current_window->buffer, 1); } else { /* remove nick from nick list and display message */ nick_free (ptr_channel, ptr_nick); irc_display_prefix (ptr_channel->buffer, PREFIX_PART); gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT_NICK, "%s ", host); gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT_DARK, "("); gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT_HOST, "%s", pos+1); gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT_DARK, ")"); gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT, _(" has left ")); gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT_CHANNEL, "%s", ptr_channel->name); if (pos_args && pos_args[0]) { gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT_DARK, " ("); gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT, "%s", pos_args); gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT_DARK, ")"); } gui_printf (ptr_channel->buffer, "\n"); if (gui_buffer_has_nicklist (ptr_channel->buffer)) gui_draw_buffer_nick (ptr_channel->buffer, 1); gui_draw_buffer_status (ptr_channel->buffer, 1); } } } else { irc_display_prefix (server->buffer, PREFIX_ERROR); gui_printf_nolog (server->buffer, _("%s channel \"%s\" not found for \"%s\" command\n"), WEECHAT_ERROR, arguments, "part"); return -1; } return 0; } /* * irc_cmd_recv_ping: 'ping' command received */ int irc_cmd_recv_ping (t_irc_server *server, char *host, char *arguments) { char *pos; (void)host; pos = strrchr (arguments, ' '); if (pos) pos[0] = '\0'; server_sendf (server, "PONG :%s\r\n", arguments); return 0; } /* * irc_cmd_recv_pong: 'pong' command received */ int irc_cmd_recv_pong (t_irc_server *server, char *host, char *arguments) { struct timeval tv; struct timezone tz; int old_lag; (void)host; (void)arguments; if (server->lag_check_time.tv_sec != 0) { /* calculate lag (time diff with lag check) */ old_lag = server->lag; gettimeofday (&tv, &tz); server->lag = (int) get_timeval_diff (&(server->lag_check_time), &tv); if (old_lag != server->lag) gui_draw_buffer_status (gui_current_window->buffer, 1); /* schedule next lag check */ server->lag_check_time.tv_sec = 0; server->lag_check_time.tv_usec = 0; server->lag_next_check = time (NULL) + cfg_irc_lag_check; } return 0; } /* * irc_cmd_recv_privmsg: 'privmsg' command received */ int irc_cmd_recv_privmsg (t_irc_server *server, char *host, char *arguments) { char *pos, *pos2, *host2; char *pos_file, *pos_addr, *pos_port, *pos_size; /* for DCC */ t_irc_channel *ptr_channel; t_irc_nick *ptr_nick; struct utsname *buf; /* no host => we can't identify sender of message! */ if (host == NULL) { irc_display_prefix (server->buffer, PREFIX_ERROR); gui_printf_nolog (server->buffer, _("%s \"%s\" command received without host\n"), WEECHAT_ERROR, "privmsg"); return -1; } /* keep only nick name from host */ pos = strchr (host, '!'); if (pos) { pos[0] = '\0'; host2 = pos+1; } else host2 = host; /* receiver is a channel ? */ if (string_is_channel (arguments)) { pos = strchr (arguments, ' '); if (pos) { pos[0] = '\0'; pos++; while (pos[0] == ' ') pos++; if (pos[0] == ':') pos++; ptr_channel = channel_search (server, arguments); if (ptr_channel) { if (strncmp (pos, "\01ACTION ", 8) == 0) { pos += 8; pos2 = strchr (pos, '\01'); if (pos2) pos2[0] = '\0'; irc_display_prefix (ptr_channel->buffer, PREFIX_ACTION_ME); if (strstr (pos, server->nick)) { gui_printf_type_color (ptr_channel->buffer, MSG_TYPE_MSG | MSG_TYPE_HIGHLIGHT, COLOR_WIN_CHAT_HIGHLIGHT, "%s", host); if ( (cfg_look_infobar) && (cfg_look_infobar_delay_highlight > 0) && (ptr_channel->buffer != gui_current_window->buffer) ) gui_infobar_printf (cfg_look_infobar_delay_highlight, COLOR_WIN_INFOBAR_HIGHLIGHT, _("On %s: * %s %s"), ptr_channel->name, host, pos); } else gui_printf_type_color (ptr_channel->buffer, MSG_TYPE_MSG, COLOR_WIN_CHAT_NICK, "%s", host); gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT, " %s\n", pos); } else if (strncmp (pos, "\01SOUND ", 7) == 0) { pos += 7; pos2 = strchr (pos, '\01'); if (pos2) pos2[0] = '\0'; irc_display_prefix (ptr_channel->buffer, PREFIX_INFO); gui_printf (ptr_channel->buffer, _("Received a CTCP SOUND \"%s\" from "), pos); gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT_NICK, "%s\n", host); } else { ptr_nick = nick_search (ptr_channel, host); if (ptr_nick) { if (strstr (pos, server->nick)) { irc_display_nick (ptr_channel->buffer, ptr_nick, MSG_TYPE_NICK | MSG_TYPE_HIGHLIGHT, 1, -1, 0); if ( (cfg_look_infobar) && (cfg_look_infobar_delay_highlight > 0) && (ptr_channel->buffer != gui_current_window->buffer) ) gui_infobar_printf (cfg_look_infobar_delay_highlight, COLOR_WIN_INFOBAR_HIGHLIGHT, _("On %s: %s> %s"), ptr_channel->name, host, pos); } else irc_display_nick (ptr_channel->buffer, ptr_nick, MSG_TYPE_NICK, 1, 1, 0); gui_printf_type_color (ptr_channel->buffer, MSG_TYPE_MSG, COLOR_WIN_CHAT, "%s\n", pos); } else { irc_display_prefix (server->buffer, PREFIX_ERROR); gui_printf_nolog (server->buffer, _("%s nick \"%s\" not found for \"%s\" command (message: \"%s\")\n"), WEECHAT_ERROR, host, "privmsg", pos); return -1; } } } else { irc_display_prefix (server->buffer, PREFIX_ERROR); gui_printf_nolog (server->buffer, _("%s channel \"%s\" not found for \"%s\" command\n"), WEECHAT_ERROR, arguments, "privmsg"); return -1; } } } else { pos = strchr (host, '!'); if (pos) pos[0] = '\0'; pos = strchr (arguments, ' '); if (pos) { pos[0] = '\0'; pos++; while (pos[0] == ' ') pos++; if (pos[0] == ':') pos++; /* version asked by another user => answer with WeeChat version */ if (strcmp (pos, "\01VERSION\01") == 0) { buf = (struct utsname *) malloc (sizeof (struct utsname)); if (buf && (uname (buf) == 0)) { server_sendf (server, "NOTICE %s :%sVERSION %s v%s" " compiled on %s, running " "%s %s / %s%s", host, "\01", PACKAGE_NAME, PACKAGE_VERSION, __DATE__, &buf->sysname, &buf->release, &buf->machine, "\01\r\n"); free (buf); } else server_sendf (server, "NOTICE %s :%sVERSION %s v%s" " compiled on %s%s", host, "\01", PACKAGE_NAME, PACKAGE_VERSION, __DATE__, "\01\r\n"); irc_display_prefix (server->buffer, PREFIX_INFO); gui_printf_color (server->buffer, COLOR_WIN_CHAT, _("Received a ")); gui_printf_color (server->buffer, COLOR_WIN_CHAT_CHANNEL, _("CTCP VERSION ")); gui_printf_color (server->buffer, COLOR_WIN_CHAT, _("from")); gui_printf_color (server->buffer, COLOR_WIN_CHAT_NICK, " %s\n", host); return 0; } /* ping request from another user => answer */ if (strncmp (pos, "\01PING", 5) == 0) { pos += 5; while (pos[0] == ' ') pos++; pos2 = strchr (pos, '\01'); if (pos2) pos2[0] = '\0'; else pos = NULL; if (pos && !pos[0]) pos = NULL; if (pos) server_sendf (server, "NOTICE %s :\01PING %s\01\r\n", host, pos); else server_sendf (server, "NOTICE %s :\01PING\01\r\n", host); return 0; } /* incoming DCC file */ if (strncmp (pos, "\01DCC SEND", 9) == 0) { /* check if DCC SEND is ok, i.e. with 0x01 at end */ pos2 = strchr (pos + 1, '\01'); if (!pos2) { irc_display_prefix (server->buffer, PREFIX_ERROR); gui_printf_nolog (server->buffer, _("%s cannot parse \"%s\" command\n"), WEECHAT_ERROR, "privmsg"); return -1; } pos2[0] = '\0'; /* DCC filename */ pos_file = pos + 9; while (pos_file[0] == ' ') pos_file++; /* look for file size */ pos_size = strrchr (pos_file, ' '); if (!pos_size) { irc_display_prefix (server->buffer, PREFIX_ERROR); gui_printf_nolog (server->buffer, _("%s cannot parse \"%s\" command\n"), WEECHAT_ERROR, "privmsg"); return -1; } pos2 = pos_size; pos_size++; while (pos2[0] == ' ') pos2--; pos2[1] = '\0'; /* look for DCC port */ pos_port = strrchr (pos_file, ' '); if (!pos_port) { irc_display_prefix (server->buffer, PREFIX_ERROR); gui_printf_nolog (server->buffer, _("%s cannot parse \"%s\" command\n"), WEECHAT_ERROR, "privmsg"); return -1; } pos2 = pos_port; pos_port++; while (pos2[0] == ' ') pos2--; pos2[1] = '\0'; /* look for DCC IP address */ pos_addr = strrchr (pos_file, ' '); if (!pos_addr) { irc_display_prefix (server->buffer, PREFIX_ERROR); gui_printf_nolog (server->buffer, _("%s cannot parse \"%s\" command\n"), WEECHAT_ERROR, "privmsg"); return -1; } pos2 = pos_addr; pos_addr++; while (pos2[0] == ' ') pos2--; pos2[1] = '\0'; dcc_add (server, DCC_FILE_RECV, (unsigned long) atol (pos_addr), atoi (pos_port), host, -1, pos_file, NULL, (unsigned long) atol (pos_size)); return 0; } /* incoming DCC CHAT */ if (strncmp (pos, "\01DCC CHAT", 9) == 0) { /* check if DCC CHAT is ok, i.e. with 0x01 at end */ pos2 = strchr (pos + 1, '\01'); if (!pos2) { irc_display_prefix (server->buffer, PREFIX_ERROR); gui_printf_nolog (server->buffer, _("%s cannot parse \"%s\" command\n"), WEECHAT_ERROR, "privmsg"); return -1; } pos2[0] = '\0'; /* CHAT type */ pos_file = pos + 9; while (pos_file[0] == ' ') pos_file++; /* DCC IP address */ pos_addr = strchr (pos_file, ' '); if (!pos_addr) { irc_display_prefix (server->buffer, PREFIX_ERROR); gui_printf_nolog (server->buffer, _("%s cannot parse \"%s\" command\n"), WEECHAT_ERROR, "privmsg"); return -1; } pos_addr[0] = '\0'; pos_addr++; while (pos_addr[0] == ' ') pos_addr++; /* look for DCC port */ pos_port = strchr (pos_addr, ' '); if (!pos_port) { irc_display_prefix (server->buffer, PREFIX_ERROR); gui_printf_nolog (server->buffer, _("%s cannot parse \"%s\" command\n"), WEECHAT_ERROR, "privmsg"); return -1; } pos_port[0] = '\0'; pos_port++; while (pos_port[0] == ' ') pos_port++; if (strcasecmp (pos_file, "chat") != 0) { irc_display_prefix (server->buffer, PREFIX_ERROR); gui_printf_nolog (server->buffer, _("%s unknown DCC CHAT type received from "), WEECHAT_ERROR); gui_printf_color (server->buffer, COLOR_WIN_CHAT_NICK, "%s", host); gui_printf (server->buffer, ": \"%s\"\n", pos_file); return -1; } dcc_add (server, DCC_CHAT_RECV, (unsigned long) atol (pos_addr), atoi (pos_port), host, -1, NULL, NULL, 0); return 0; } /* private message received => display it */ ptr_channel = channel_search (server, host); if (!ptr_channel) { ptr_channel = channel_new (server, CHAT_PRIVATE, host, 0); if (!ptr_channel) { irc_display_prefix (server->buffer, PREFIX_ERROR); gui_printf_nolog (server->buffer, _("%s cannot create new private window \"%s\"\n"), WEECHAT_ERROR, host); return -1; } } if (!ptr_channel->topic) ptr_channel->topic = strdup (host2); if (strncmp (pos, "\01ACTION ", 8) == 0) { pos += 8; pos2 = strchr (pos, '\01'); if (pos2) pos2[0] = '\0'; irc_display_prefix (ptr_channel->buffer, PREFIX_ACTION_ME); if (strstr (pos, server->nick)) { gui_printf_type_color (ptr_channel->buffer, MSG_TYPE_MSG | MSG_TYPE_HIGHLIGHT, COLOR_WIN_CHAT_HIGHLIGHT, "%s", host); if ( (cfg_look_infobar) && (cfg_look_infobar_delay_highlight > 0) && (ptr_channel->buffer != gui_current_window->buffer) ) gui_infobar_printf (cfg_look_infobar_delay_highlight, COLOR_WIN_INFOBAR_HIGHLIGHT, _("On %s: * %s %s"), ptr_channel->name, host, pos); } else gui_printf_type_color (ptr_channel->buffer, MSG_TYPE_MSG, COLOR_WIN_CHAT_NICK, "%s", host); gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT, " %s\n", pos); } else { gui_printf_type_color (ptr_channel->buffer, MSG_TYPE_NICK, COLOR_WIN_CHAT_DARK, "<"); if (strstr (pos, server->nick)) { gui_printf_type_color (ptr_channel->buffer, MSG_TYPE_NICK | MSG_TYPE_HIGHLIGHT, COLOR_WIN_CHAT_HIGHLIGHT, "%s", host); if ( (cfg_look_infobar_delay_highlight > 0) && (ptr_channel->buffer != gui_current_window->buffer) ) gui_infobar_printf (cfg_look_infobar_delay_highlight, COLOR_WIN_INFOBAR_HIGHLIGHT, _("Private %s> %s"), host, pos); } else gui_printf_type_color (ptr_channel->buffer, MSG_TYPE_NICK, COLOR_WIN_NICK_PRIVATE, "%s", host); gui_printf_type_color (ptr_channel->buffer, MSG_TYPE_NICK, COLOR_WIN_CHAT_DARK, "> "); gui_printf_type_color (ptr_channel->buffer, MSG_TYPE_MSG, COLOR_WIN_CHAT, "%s\n", pos); } } else { irc_display_prefix (server->buffer, PREFIX_ERROR); gui_printf_nolog (server->buffer, _("%s cannot parse \"%s\" command\n"), WEECHAT_ERROR, "privmsg"); return -1; } } return 0; } /* * irc_cmd_recv_quit: 'quit' command received */ int irc_cmd_recv_quit (t_irc_server *server, char *host, char *arguments) { char *pos; t_irc_channel *ptr_channel; t_irc_nick *ptr_nick; /* no host => we can't identify sender of message! */ if (host == NULL) { irc_display_prefix (server->buffer, PREFIX_ERROR); gui_printf_nolog (server->buffer, _("%s \"%s\" command received without host\n"), WEECHAT_ERROR, "quit"); return -1; } /* keep only nick name from host */ pos = strchr (host, '!'); if (pos) pos[0] = '\0'; for (ptr_channel = server->channels; ptr_channel; ptr_channel = ptr_channel->next_channel) { if (ptr_channel->type == CHAT_PRIVATE) ptr_nick = NULL; else ptr_nick = nick_search (ptr_channel, host); if (ptr_nick || (strcmp (ptr_channel->name, host) == 0)) { if (ptr_nick) nick_free (ptr_channel, ptr_nick); irc_display_prefix (ptr_channel->buffer, PREFIX_QUIT); gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT_NICK, "%s ", host); gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT_DARK, "("); gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT_HOST, "%s", pos + 1); gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT_DARK, ") "); gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT, _("has quit")); gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT_DARK, " ("); gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT, "%s", arguments); gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT_DARK, ")\n"); if (gui_buffer_has_nicklist (ptr_channel->buffer)) gui_draw_buffer_nick (ptr_channel->buffer, 1); gui_draw_buffer_status (ptr_channel->buffer, 1); } } return 0; } /* * irc_cmd_recv_server_msg: command received from server (numeric) */ int irc_cmd_recv_server_msg (t_irc_server *server, char *host, char *arguments) { /* make gcc happy */ (void) host; /* skip nickname if at beginning of server message */ if (strncmp (server->nick, arguments, strlen (server->nick)) == 0) { arguments += strlen (server->nick) + 1; while (arguments[0] == ' ') arguments++; } if (arguments[0] == ':') arguments++; /* display server message */ irc_display_prefix (server->buffer, PREFIX_SERVER); gui_printf_color (server->buffer, COLOR_WIN_CHAT, "%s\n", arguments); return 0; } /* * irc_cmd_recv_server_reply: server reply */ int irc_cmd_recv_server_reply (t_irc_server *server, char *host, char *arguments) { char *pos, *pos2; int first; /* make gcc happy */ (void) server; (void) host; pos = strchr (arguments, ' '); if (pos) { pos[0] = '\0'; pos++; while (pos[0] == ' ') pos++; } else pos = arguments; irc_display_prefix (server->buffer, PREFIX_ERROR); first = 1; while (pos && pos[0]) { pos2 = strchr (pos, ' '); if ((pos[0] == ':') || (!pos2)) { if (pos[0] == ':') pos++; gui_printf_color (server->buffer, COLOR_WIN_CHAT, "%s%s\n", (first) ? "" : ": ", pos); pos = NULL; } else { pos2[0] = '\0'; gui_printf_color (server->buffer, COLOR_WIN_CHAT_CHANNEL, "%s%s\n", (first) ? "" : " ", pos); first = 0; pos = pos2 + 1; } } return 0; } /* * irc_cmd_recv_topic: 'topic' command received */ int irc_cmd_recv_topic (t_irc_server *server, char *host, char *arguments) { char *pos; t_irc_channel *ptr_channel; t_gui_buffer *buffer; /* make gcc happy */ (void) host; /* keep only nick name from host */ pos = strchr (host, '!'); if (pos) pos[0] = '\0'; if (!string_is_channel (arguments)) { irc_display_prefix (server->buffer, PREFIX_ERROR); gui_printf_nolog (server->buffer, _("%s \"%s\" command received without channel\n"), WEECHAT_ERROR, "topic"); return -1; } pos = strchr (arguments, ' '); if (pos) { pos[0] = '\0'; pos++; while (pos[0] == ' ') pos++; if (pos[0] == ':') pos++; if (!pos[0]) pos = NULL; } ptr_channel = channel_search (server, arguments); buffer = (ptr_channel) ? ptr_channel->buffer : server->buffer; irc_display_prefix (buffer, PREFIX_INFO); gui_printf_color (buffer, COLOR_WIN_CHAT_NICK, "%s", host); if (pos) { gui_printf_color (buffer, COLOR_WIN_CHAT, _(" has changed topic for ")); gui_printf_color (buffer, COLOR_WIN_CHAT_CHANNEL, "%s", arguments); gui_printf_color (buffer, COLOR_WIN_CHAT, _(" to: \"%s\"\n"), pos); } else { gui_printf_color (buffer, COLOR_WIN_CHAT, _(" has unset topic for ")); gui_printf_color (buffer, COLOR_WIN_CHAT_CHANNEL, "%s\n", arguments); } if (ptr_channel) { if (ptr_channel->topic) free (ptr_channel->topic); if (pos) ptr_channel->topic = strdup (pos); else ptr_channel->topic = strdup (""); gui_draw_buffer_title (ptr_channel->buffer, 1); } return 0; } /* * irc_cmd_recv_004: '004' command (connected to irc server) */ int irc_cmd_recv_004 (t_irc_server *server, char *host, char *arguments) { char *pos; t_irc_channel *ptr_channel; /* make gcc happy */ (void) host; pos = strchr (arguments, ' '); if (pos) pos[0] = '\0'; if (strcmp (server->nick, arguments) != 0) { free (server->nick); server->nick = strdup (arguments); } irc_cmd_recv_server_msg (server, host, arguments); /* connection to IRC server is ok! */ server->is_connected = 1; server->lag_next_check = time (NULL) + cfg_irc_lag_check; gui_draw_buffer_status (server->buffer, 1); gui_draw_buffer_input (server->buffer, 1); /* execute command once connected */ if (server->command && server->command[0]) { user_command(server, NULL, server->command); if (server->command_delay > 0) sleep (server->command_delay); } /* auto-join after disconnection (only rejoins opened channels) */ if (server->reconnect_join && server->channels) { for (ptr_channel = server->channels; ptr_channel; ptr_channel = ptr_channel->next_channel) { if (ptr_channel->type == CHAT_CHANNEL) server_sendf (server, "JOIN %s\r\n", ptr_channel->name); } server->reconnect_join = 0; } else { /* auto-join when connecting to server for first time */ if (server->autojoin && server->autojoin[0]) return irc_cmd_send_join (server, server->autojoin); } return 0; } /* * irc_cmd_recv_301: '301' command (away message) */ int irc_cmd_recv_301 (t_irc_server *server, char *host, char *arguments) { char *pos_nick, *pos_message; /* make gcc happy */ (void) server; (void) host; pos_nick = strchr (arguments, ' '); if (pos_nick) { while (pos_nick[0] == ' ') pos_nick++; pos_message = strchr (pos_nick, ' '); if (pos_message) { pos_message[0] = '\0'; pos_message++; while (pos_message[0] == ' ') pos_message++; if (pos_message[0] == ':') pos_message++; irc_display_prefix (gui_current_window->buffer, PREFIX_INFO); gui_printf_color (gui_current_window->buffer, COLOR_WIN_CHAT_NICK, "%s", pos_nick); gui_printf_color (gui_current_window->buffer, COLOR_WIN_CHAT, _(" is away: %s\n"), pos_message); } } return 0; } /* * irc_cmd_recv_302: '302' command (userhost) */ int irc_cmd_recv_302 (t_irc_server *server, char *host, char *arguments) { char *pos_host, *ptr_next; /* make gcc happy */ (void) host; arguments = strchr (arguments, ' '); if (arguments) { while (arguments[0] == ' ') arguments++; if (arguments[0] == ':') arguments++; while (arguments) { pos_host = strchr (arguments, '='); if (pos_host) { pos_host[0] = '\0'; pos_host++; ptr_next = strchr (pos_host, ' '); if (ptr_next) { ptr_next[0] = '\0'; ptr_next++; while (ptr_next[0] == ' ') ptr_next++; } irc_display_prefix (server->buffer, PREFIX_SERVER); gui_printf_color (server->buffer, COLOR_WIN_CHAT_NICK, "%s", arguments); gui_printf_color (server->buffer, COLOR_WIN_CHAT, "="); gui_printf_color (server->buffer, COLOR_WIN_CHAT_HOST, "%s\n", pos_host); } else ptr_next = NULL; arguments = ptr_next; if (arguments && !arguments[0]) arguments = NULL; } } return 0; } /* * irc_cmd_recv_303: '303' command (ison) */ int irc_cmd_recv_303 (t_irc_server *server, char *host, char *arguments) { char *ptr_next; /* make gcc happy */ (void) host; irc_display_prefix (server->buffer, PREFIX_SERVER); gui_printf_color (server->buffer, COLOR_WIN_CHAT, _("Users online: ")); arguments = strchr (arguments, ' '); if (arguments) { while (arguments[0] == ' ') arguments++; if (arguments[0] == ':') arguments++; while (arguments) { ptr_next = strchr (arguments, ' '); if (ptr_next) { ptr_next[0] = '\0'; ptr_next++; while (ptr_next[0] == ' ') ptr_next++; } gui_printf_color (server->buffer, COLOR_WIN_CHAT_NICK, "%s ", arguments); arguments = ptr_next; if (arguments && !arguments[0]) arguments = NULL; } } gui_printf (server->buffer, "\n"); return 0; } /* * irc_cmd_recv_305: '305' command (unaway) */ int irc_cmd_recv_305 (t_irc_server *server, char *host, char *arguments) { /* make gcc happy */ (void) host; arguments = strchr (arguments, ' '); if (arguments) { while (arguments[0] == ' ') arguments++; if (arguments[0] == ':') arguments++; irc_display_prefix (server->buffer, PREFIX_SERVER); gui_printf_color (server->buffer, COLOR_WIN_CHAT, "%s\n", arguments); } server->is_away = 0; server->away_time = 0; return 0; } /* * irc_cmd_recv_306: '306' command (now away) */ int irc_cmd_recv_306 (t_irc_server *server, char *host, char *arguments) { /* make gcc happy */ (void) host; arguments = strchr (arguments, ' '); if (arguments) { while (arguments[0] == ' ') arguments++; if (arguments[0] == ':') arguments++; irc_display_prefix (server->buffer, PREFIX_SERVER); gui_printf_color (server->buffer, COLOR_WIN_CHAT, "%s\n", arguments); } server->is_away = 1; server->away_time = time (NULL); return 0; } /* * irc_cmd_recv_307: '307' command (whois, registered nick) */ int irc_cmd_recv_307 (t_irc_server *server, char *host, char *arguments) { char *pos_nick, *pos_msg; /* make gcc happy */ (void) host; pos_nick = strchr (arguments, ' '); if (pos_nick) { while (pos_nick[0] == ' ') pos_nick++; pos_msg = strchr (pos_nick, ' '); if (pos_msg) { pos_msg[0] = '\0'; pos_msg++; while (pos_msg[0] == ' ') pos_msg++; if (pos_msg[0] == ':') pos_msg++; irc_display_prefix (server->buffer, PREFIX_SERVER); gui_printf_color (server->buffer, COLOR_WIN_CHAT_DARK, "["); gui_printf_color (server->buffer, COLOR_WIN_CHAT_NICK, "%s", pos_nick); gui_printf_color (server->buffer, COLOR_WIN_CHAT_DARK, "] "); gui_printf_color (server->buffer, COLOR_WIN_CHAT, "%s\n", pos_msg); } } return 0; } /* * irc_cmd_recv_311: '311' command (whois, user) */ int irc_cmd_recv_311 (t_irc_server *server, char *host, char *arguments) { char *pos_nick, *pos_user, *pos_host, *pos_realname; /* make gcc happy */ (void) host; pos_nick = strchr (arguments, ' '); if (pos_nick) { while (pos_nick[0] == ' ') pos_nick++; pos_user = strchr (pos_nick, ' '); if (pos_user) { pos_user[0] = '\0'; pos_user++; while (pos_user[0] == ' ') pos_user++; pos_host = strchr (pos_user, ' '); if (pos_host) { pos_host[0] = '\0'; pos_host++; while (pos_host[0] == ' ') pos_host++; pos_realname = strchr (pos_host, ' '); if (pos_realname) { pos_realname[0] = '\0'; pos_realname++; while (pos_realname[0] == ' ') pos_realname++; if (pos_realname[0] == '*') pos_realname++; while (pos_realname[0] == ' ') pos_realname++; if (pos_realname[0] == ':') pos_realname++; irc_display_prefix (server->buffer, PREFIX_SERVER); gui_printf_color (server->buffer, COLOR_WIN_CHAT_DARK, "["); gui_printf_color (server->buffer, COLOR_WIN_CHAT_NICK, "%s", pos_nick); gui_printf_color (server->buffer, COLOR_WIN_CHAT_DARK, "] ("); gui_printf_color (server->buffer, COLOR_WIN_CHAT_HOST, "%s@%s", pos_user, pos_host); gui_printf_color (server->buffer, COLOR_WIN_CHAT_DARK, ")"); gui_printf_color (server->buffer, COLOR_WIN_CHAT, ": %s\n", pos_realname); } } } } return 0; } /* * irc_cmd_recv_312: '312' command (whois, server) */ int irc_cmd_recv_312 (t_irc_server *server, char *host, char *arguments) { char *pos_nick, *pos_server, *pos_serverinfo; /* make gcc happy */ (void) host; pos_nick = strchr (arguments, ' '); if (pos_nick) { while (pos_nick[0] == ' ') pos_nick++; pos_server = strchr (pos_nick, ' '); if (pos_server) { pos_server[0] = '\0'; pos_server++; while (pos_server[0] == ' ') pos_server++; pos_serverinfo = strchr (pos_server, ' '); if (pos_serverinfo) { pos_serverinfo[0] = '\0'; pos_serverinfo++; while (pos_serverinfo[0] == ' ') pos_serverinfo++; if (pos_serverinfo[0] == ':') pos_serverinfo++; irc_display_prefix (server->buffer, PREFIX_SERVER); gui_printf_color (server->buffer, COLOR_WIN_CHAT_DARK, "["); gui_printf_color (server->buffer, COLOR_WIN_CHAT_NICK, "%s", pos_nick); gui_printf_color (server->buffer, COLOR_WIN_CHAT_DARK, "] "); gui_printf_color (server->buffer, COLOR_WIN_CHAT, "%s ", pos_server); gui_printf_color (server->buffer, COLOR_WIN_CHAT_DARK, "("); gui_printf_color (server->buffer, COLOR_WIN_CHAT, "%s", pos_serverinfo); gui_printf_color (server->buffer, COLOR_WIN_CHAT_DARK, ")\n"); } } } return 0; } /* * irc_cmd_recv_313: '313' command (whois, operator) */ int irc_cmd_recv_313 (t_irc_server *server, char *host, char *arguments) { char *pos_nick, *pos_message; /* make gcc happy */ (void) host; pos_nick = strchr (arguments, ' '); if (pos_nick) { while (pos_nick[0] == ' ') pos_nick++; pos_message = strchr (pos_nick, ' '); if (pos_message) { pos_message[0] = '\0'; pos_message++; while (pos_message[0] == ' ') pos_message++; if (pos_message[0] == ':') pos_message++; irc_display_prefix (server->buffer, PREFIX_SERVER); gui_printf_color (server->buffer, COLOR_WIN_CHAT_DARK, "["); gui_printf_color (server->buffer, COLOR_WIN_CHAT_NICK, "%s", pos_nick); gui_printf_color (server->buffer, COLOR_WIN_CHAT_DARK, "] "); gui_printf_color (server->buffer, COLOR_WIN_CHAT, "%s\n", pos_message); } } return 0; } /* * irc_cmd_recv_314: '314' command (whowas) */ int irc_cmd_recv_314 (t_irc_server *server, char *host, char *arguments) { char *pos_nick, *pos_user, *pos_host, *pos_realname; /* make gcc happy */ (void) host; pos_nick = strchr (arguments, ' '); if (pos_nick) { while (pos_nick[0] == ' ') pos_nick++; pos_user = strchr (pos_nick, ' '); if (pos_user) { pos_user[0] = '\0'; pos_user++; while (pos_user[0] == ' ') pos_user++; pos_host = strchr (pos_user, ' '); if (pos_host) { pos_host[0] = '\0'; pos_host++; while (pos_host[0] == ' ') pos_host++; pos_realname = strchr (pos_host, ' '); if (pos_realname) { pos_realname[0] = '\0'; pos_realname++; while (pos_realname[0] == ' ') pos_realname++; pos_realname = strchr (pos_realname, ' '); if (pos_realname) { pos_realname[0] = '\0'; pos_realname++; while (pos_realname[0] == ' ') pos_realname++; if (pos_realname[0] == ':') pos_realname++; irc_display_prefix (server->buffer, PREFIX_SERVER); gui_printf_color (server->buffer, COLOR_WIN_CHAT_NICK, "%s", pos_nick); gui_printf_color (server->buffer, COLOR_WIN_CHAT_DARK, " ("); gui_printf_color (server->buffer, COLOR_WIN_CHAT_HOST, "%s@%s", pos_user, pos_host); gui_printf_color (server->buffer, COLOR_WIN_CHAT_DARK, ")"); gui_printf_color (server->buffer, COLOR_WIN_CHAT, " was %s\n", pos_realname); } } } } } return 0; } /* * irc_cmd_recv_315: '315' command (end of /who) */ int irc_cmd_recv_315 (t_irc_server *server, char *host, char *arguments) { char *pos; t_irc_channel *ptr_channel; /* make gcc happy */ (void) host; /* skip nickname if at beginning of server message */ if (strncmp (server->nick, arguments, strlen (server->nick)) == 0) { arguments += strlen (server->nick) + 1; while (arguments[0] == ' ') arguments++; } pos = strchr (arguments, ' '); if (pos) { pos[0] = '\0'; pos++; ptr_channel = channel_search (server, arguments); if (ptr_channel && (ptr_channel->checking_away > 0)) { ptr_channel->checking_away--; return 0; } gui_printf_color (server->buffer, COLOR_WIN_CHAT_CHANNEL, "%s", arguments); gui_printf (server->buffer, " %s\n", pos); } else gui_printf (server->buffer, "%s\n", arguments); return 0; } /* * irc_cmd_recv_317: '317' command (whois, idle) */ int irc_cmd_recv_317 (t_irc_server *server, char *host, char *arguments) { char *pos_nick, *pos_idle, *pos_signon, *pos_message; int idle_time, day, hour, min, sec; time_t datetime; /* make gcc happy */ (void) host; pos_nick = strchr (arguments, ' '); if (pos_nick) { while (pos_nick[0] == ' ') pos_nick++; pos_idle = strchr (pos_nick, ' '); if (pos_idle) { pos_idle[0] = '\0'; pos_idle++; while (pos_idle[0] == ' ') pos_idle++; pos_signon = strchr (pos_idle, ' '); if (pos_signon) { pos_signon[0] = '\0'; pos_signon++; while (pos_signon[0] == ' ') pos_signon++; pos_message = strchr (pos_signon, ' '); if (pos_message) { pos_message[0] = '\0'; idle_time = atoi (pos_idle); day = idle_time / (60 * 60 * 24); hour = (idle_time % (60 * 60 * 24)) / (60 * 60); min = ((idle_time % (60 * 60 * 24)) % (60 * 60)) / 60; sec = ((idle_time % (60 * 60 * 24)) % (60 * 60)) % 60; irc_display_prefix (server->buffer, PREFIX_SERVER); gui_printf_color (server->buffer, COLOR_WIN_CHAT_DARK, "["); gui_printf_color (server->buffer, COLOR_WIN_CHAT_NICK, "%s", pos_nick); gui_printf_color (server->buffer, COLOR_WIN_CHAT_DARK, "] "); gui_printf_color (server->buffer, COLOR_WIN_CHAT, _("idle: ")); if (day > 0) { gui_printf_color (server->buffer, COLOR_WIN_CHAT_CHANNEL, "%d ", day); gui_printf_color (server->buffer, COLOR_WIN_CHAT, (day > 1) ? _("days") : _("day")); gui_printf_color (server->buffer, COLOR_WIN_CHAT, ", "); } gui_printf_color (server->buffer, COLOR_WIN_CHAT_CHANNEL, "%02d ", hour); gui_printf_color (server->buffer, COLOR_WIN_CHAT, (hour > 1) ? _("hours") : _("hour")); gui_printf_color (server->buffer, COLOR_WIN_CHAT_CHANNEL, " %02d ", min); gui_printf_color (server->buffer, COLOR_WIN_CHAT, (min > 1) ? _("minutes") : _("minute")); gui_printf_color (server->buffer, COLOR_WIN_CHAT_CHANNEL, " %02d ", sec); gui_printf_color (server->buffer, COLOR_WIN_CHAT, (sec > 1) ? _("seconds") : _("second")); gui_printf_color (server->buffer, COLOR_WIN_CHAT, ", "); gui_printf_color (server->buffer, COLOR_WIN_CHAT, _("signon at: ")); datetime = (time_t)(atol (pos_signon)); gui_printf_color (server->buffer, COLOR_WIN_CHAT_CHANNEL, "%s", ctime (&datetime)); } } } } return 0; } /* * irc_cmd_recv_318: '318' command (whois, end) */ int irc_cmd_recv_318 (t_irc_server *server, char *host, char *arguments) { char *pos_nick, *pos_message; /* make gcc happy */ (void) host; pos_nick = strchr (arguments, ' '); if (pos_nick) { while (pos_nick[0] == ' ') pos_nick++; pos_message = strchr (pos_nick, ' '); if (pos_message) { pos_message[0] = '\0'; pos_message++; while (pos_message[0] == ' ') pos_message++; if (pos_message[0] == ':') pos_message++; irc_display_prefix (server->buffer, PREFIX_SERVER); gui_printf_color (server->buffer, COLOR_WIN_CHAT_DARK, "["); gui_printf_color (server->buffer, COLOR_WIN_CHAT_NICK, "%s", pos_nick); gui_printf_color (server->buffer, COLOR_WIN_CHAT_DARK, "] "); gui_printf_color (server->buffer, COLOR_WIN_CHAT, "%s\n", pos_message); } } return 0; } /* * irc_cmd_recv_319: '319' command (whois, end) */ int irc_cmd_recv_319 (t_irc_server *server, char *host, char *arguments) { char *pos_nick, *pos_channel, *pos; /* make gcc happy */ (void) host; pos_nick = strchr (arguments, ' '); if (pos_nick) { while (pos_nick[0] == ' ') pos_nick++; pos_channel = strchr (pos_nick, ' '); if (pos_channel) { pos_channel[0] = '\0'; pos_channel++; while (pos_channel[0] == ' ') pos_channel++; if (pos_channel[0] == ':') pos_channel++; irc_display_prefix (server->buffer, PREFIX_SERVER); gui_printf_color (server->buffer, COLOR_WIN_CHAT_DARK, "["); gui_printf_color (server->buffer, COLOR_WIN_CHAT_NICK, "%s", pos_nick); gui_printf_color (server->buffer, COLOR_WIN_CHAT_DARK, "] "); gui_printf_color (server->buffer, COLOR_WIN_CHAT, _("Channels: ")); while (pos_channel && pos_channel[0]) { if (pos_channel[0] == '@') { gui_printf_color (server->buffer, COLOR_WIN_NICK_OP, "@"); pos_channel++; } else { if (pos_channel[0] == '%') { gui_printf_color (server->buffer, COLOR_WIN_NICK_HALFOP, "%"); pos_channel++; } else if (pos_channel[0] == '+') { gui_printf_color (server->buffer, COLOR_WIN_NICK_VOICE, "+"); pos_channel++; } } pos = strchr (pos_channel, ' '); if (pos) { pos[0] = '\0'; pos++; while (pos[0] == ' ') pos++; } gui_printf_color (server->buffer, COLOR_WIN_CHAT_CHANNEL, "%s%s", pos_channel, (pos && pos[0]) ? " " : "\n"); pos_channel = pos; } } } return 0; } /* * irc_cmd_recv_320: '320' command (whois, identified user) */ int irc_cmd_recv_320 (t_irc_server *server, char *host, char *arguments) { char *pos_nick, *pos_message; /* make gcc happy */ (void) host; pos_nick = strchr (arguments, ' '); if (pos_nick) { while (pos_nick[0] == ' ') pos_nick++; pos_message = strchr (pos_nick, ' '); if (pos_message) { pos_message[0] = '\0'; pos_message++; while (pos_message[0] == ' ') pos_message++; if (pos_message[0] == ':') pos_message++; irc_display_prefix (server->buffer, PREFIX_SERVER); gui_printf_color (server->buffer, COLOR_WIN_CHAT_DARK, "["); gui_printf_color (server->buffer, COLOR_WIN_CHAT_NICK, "%s", pos_nick); gui_printf_color (server->buffer, COLOR_WIN_CHAT_DARK, "] "); gui_printf_color (server->buffer, COLOR_WIN_CHAT, "%s\n", pos_message); } } return 0; } /* * irc_cmd_recv_321: '321' command (/list start) */ int irc_cmd_recv_321 (t_irc_server *server, char *host, char *arguments) { char *pos; /* make gcc happy */ (void) host; pos = strchr (arguments, ' '); if (pos) { pos[0] = '\0'; pos++; while (pos[0] == ' ') pos++; } else pos = arguments; irc_display_prefix (server->buffer, PREFIX_SERVER); gui_printf (server->buffer, "%s\n", pos); return 0; } /* * irc_cmd_recv_322: '322' command (channel for /list) */ int irc_cmd_recv_322 (t_irc_server *server, char *host, char *arguments) { char *pos; /* make gcc happy */ (void) host; pos = strchr (arguments, ' '); if (pos) { pos[0] = '\0'; pos++; while (pos[0] == ' ') pos++; } else pos = arguments; irc_display_prefix (server->buffer, PREFIX_SERVER); gui_printf (server->buffer, "%s\n", pos); return 0; } /* * irc_cmd_recv_323: '323' command (/list end) */ int irc_cmd_recv_323 (t_irc_server *server, char *host, char *arguments) { char *pos; /* make gcc happy */ (void) host; pos = strchr (arguments, ' '); if (pos) { pos[0] = '\0'; pos++; while (pos[0] == ' ') pos++; } else pos = arguments; irc_display_prefix (server->buffer, PREFIX_SERVER); gui_printf (server->buffer, "%s\n", pos); return 0; } /* * irc_cmd_recv_324: '324' command (channel mode) */ int irc_cmd_recv_324 (t_irc_server *server, char *host, char *arguments) { char *pos_chan, *pos, *pos_parm; t_irc_channel *ptr_channel; /* make gcc happy */ (void) host; pos_chan = strchr (arguments, ' '); if (pos_chan) { pos_chan[0] = '\0'; pos_chan++; while (pos_chan[0] == ' ') pos_chan++; pos = strchr (pos_chan, ' '); if (pos) { pos[0] = '\0'; pos++; while (pos[0] == ' ') pos++; pos_parm = strchr (pos, ' '); if (pos_parm) { pos_parm[0] = '\0'; pos_parm++; while (pos_parm[0] == ' ') pos_parm++; } ptr_channel = channel_search (server, pos_chan); if (ptr_channel) { irc_get_channel_modes (ptr_channel, NULL, NULL, pos, pos_parm); gui_draw_buffer_status (ptr_channel->buffer, 0); } } } return 0; } /* * irc_cmd_recv_329: '329' command (???) */ int irc_cmd_recv_329 (t_irc_server *server, char *host, char *arguments) { /* make gcc happy */ (void) server; (void) host; (void) arguments; return 0; } /* * irc_cmd_recv_331: '331' command received (no topic for channel) */ int irc_cmd_recv_331 (t_irc_server *server, char *host, char *arguments) { char *pos; /* make gcc happy */ (void) server; (void) host; pos = strchr (arguments, ' '); if (pos) pos[0] = '\0'; irc_display_prefix (gui_current_window->buffer, PREFIX_INFO); gui_printf_color (gui_current_window->buffer, COLOR_WIN_CHAT, _("No topic set for ")); gui_printf_color (gui_current_window->buffer, COLOR_WIN_CHAT_CHANNEL, "%s\n", arguments); return 0; } /* * irc_cmd_recv_332: '332' command received (topic of channel) */ int irc_cmd_recv_332 (t_irc_server *server, char *host, char *arguments) { char *pos, *pos2; t_irc_channel *ptr_channel; /* make gcc happy */ (void) host; pos = strchr (arguments, ' '); if (pos) { while (pos[0] == ' ') pos++; pos2 = strchr (pos, ' '); if (pos2) { pos2[0] = '\0'; ptr_channel = channel_search (server, pos); if (ptr_channel) { pos2++; while (pos2[0] == ' ') pos2++; if (pos2[0] == ':') pos2++; if (ptr_channel->topic) free (ptr_channel->topic); ptr_channel->topic = strdup (pos2); irc_display_prefix (ptr_channel->buffer, PREFIX_INFO); gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT, _("Topic for ")); gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT_CHANNEL, "%s", pos); gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT, _(" is: \"%s\"\n"), pos2); gui_draw_buffer_title (ptr_channel->buffer, 1); } else { irc_display_prefix (server->buffer, PREFIX_ERROR); gui_printf_nolog (server->buffer, _("%s channel \"%s\" not found for \"%s\" command\n"), WEECHAT_ERROR, pos, "332"); return -1; } } } else { irc_display_prefix (server->buffer, PREFIX_ERROR); gui_printf_nolog (server->buffer, _("%s cannot identify channel for \"%s\" command\n"), WEECHAT_ERROR, "332"); return -1; } return 0; } /* * irc_cmd_recv_333: '333' command received (infos about topic (nick / date)) */ int irc_cmd_recv_333 (t_irc_server *server, char *host, char *arguments) { char *pos_channel, *pos_nick, *pos_date; t_irc_channel *ptr_channel; time_t datetime; /* make gcc happy */ (void) host; pos_channel = strchr (arguments, ' '); if (pos_channel) { while (pos_channel[0] == ' ') pos_channel++; pos_nick = strchr (pos_channel, ' '); if (pos_nick) { pos_nick[0] = '\0'; pos_nick++; while (pos_nick[0] == ' ') pos_nick++; pos_date = strchr (pos_nick, ' '); if (pos_date) { pos_date[0] = '\0'; pos_date++; while (pos_date[0] == ' ') pos_date++; ptr_channel = channel_search (server, pos_channel); if (ptr_channel) { irc_display_prefix (ptr_channel->buffer, PREFIX_INFO); gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT, _("Topic set by ")); gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT_NICK, "%s", pos_nick); datetime = (time_t)(atol (pos_date)); gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT, ", %s", ctime (&datetime)); } else { irc_display_prefix (server->buffer, PREFIX_ERROR); gui_printf_nolog (server->buffer, _("%s channel \"%s\" not found for \"%s\" command\n"), WEECHAT_ERROR, pos_channel, "333"); return -1; } } else { irc_display_prefix (server->buffer, PREFIX_ERROR); gui_printf_nolog (server->buffer, _("%s cannot identify date/time for \"%s\" command\n"), WEECHAT_ERROR, "333"); return -1; } } else { irc_display_prefix (server->buffer, PREFIX_ERROR); gui_printf_nolog (server->buffer, _("%s cannot identify nickname for \"%s\" command\n"), WEECHAT_ERROR, "333"); return -1; } } else { irc_display_prefix (server->buffer, PREFIX_ERROR); gui_printf_nolog (server->buffer, _("%s cannot identify channel for \"%s\" command\n"), WEECHAT_ERROR, "333"); return -1; } return 0; } /* * irc_cmd_recv_341: '341' command received (inviting) */ int irc_cmd_recv_341 (t_irc_server *server, char *host, char *arguments) { char *pos, *pos_nick, *pos_channel; pos = strchr (host, '!'); if (pos) pos[0] = '\0'; pos_nick = strchr (arguments, ' '); if (pos_nick) { pos_nick[0] = '\0'; pos_nick++; while (pos_nick[0] == ' ') pos_nick++; pos_channel = strchr (pos_nick, ' '); if (pos_channel) { pos_channel[0] = '\0'; pos_channel++; while (pos_channel[0] == ' ') pos_channel++; if (pos_channel[0] == ':') pos_channel++; irc_display_prefix (server->buffer, PREFIX_SERVER); gui_printf_color (server->buffer, COLOR_WIN_CHAT_NICK, "%s ", arguments); gui_printf (server->buffer, _("has invited")); gui_printf_color (server->buffer, COLOR_WIN_CHAT_NICK, " %s ", pos_nick); gui_printf (server->buffer, _("on")); gui_printf_color (server->buffer, COLOR_WIN_CHAT_CHANNEL, " %s\n", pos_channel); gui_draw_buffer_status (gui_current_window->buffer, 1); } else { irc_display_prefix (server->buffer, PREFIX_ERROR); gui_printf_nolog (server->buffer, _("%s cannot identify channel for \"%s\" command\n"), WEECHAT_ERROR, "341"); return -1; } } else { irc_display_prefix (server->buffer, PREFIX_ERROR); gui_printf_nolog (server->buffer, _("%s cannot identify nickname for \"%s\" command\n"), WEECHAT_ERROR, "341"); return -1; } return 0; } /* * irc_cmd_recv_351: '351' command received (server version) */ int irc_cmd_recv_351 (t_irc_server *server, char *host, char *arguments) { char *pos, *pos2; /* make gcc happy */ (void) server; (void) host; pos = strchr (arguments, ' '); if (pos) { pos[0] = '\0'; pos++; } else pos = arguments; pos2 = strstr (pos, " :"); if (pos2) { pos2[0] = '\0'; pos2 += 2; } irc_display_prefix (server->buffer, PREFIX_SERVER); if (pos2) gui_printf (server->buffer, "%s %s\n", pos, pos2); else gui_printf (server->buffer, "%s\n", pos); return 0; } /* * irc_cmd_recv_352: '352' command (who) */ int irc_cmd_recv_352 (t_irc_server *server, char *host, char *arguments) { char *pos_channel, *pos_user, *pos_host, *pos_server, *pos_nick; char *pos_attr, *pos_hopcount, *pos_realname; t_irc_channel *ptr_channel; t_irc_nick *ptr_nick; /* make gcc happy */ (void) host; pos_channel = strchr (arguments, ' '); if (pos_channel) { while (pos_channel[0] == ' ') pos_channel++; pos_user = strchr (pos_channel, ' '); if (pos_user) { pos_user[0] = '\0'; pos_user++; while (pos_user[0] == ' ') pos_user++; pos_host = strchr (pos_user, ' '); if (pos_host) { pos_host[0] = '\0'; pos_host++; while (pos_host[0] == ' ') pos_host++; pos_server = strchr (pos_host, ' '); if (pos_server) { pos_server[0] = '\0'; pos_server++; while (pos_server[0] == ' ') pos_server++; pos_nick = strchr (pos_server, ' '); if (pos_nick) { pos_nick[0] = '\0'; pos_nick++; while (pos_nick[0] == ' ') pos_nick++; pos_attr = strchr (pos_nick, ' '); if (pos_attr) { pos_attr[0] = '\0'; pos_attr++; while (pos_attr[0] == ' ') pos_attr++; pos_hopcount = strchr (pos_attr, ' '); if (pos_hopcount) { pos_hopcount[0] = '\0'; pos_hopcount++; while (pos_hopcount[0] == ' ') pos_hopcount++; if (pos_hopcount[0] == ':') pos_hopcount++; pos_realname = strchr (pos_hopcount, ' '); if (pos_realname) { pos_realname[0] = '\0'; pos_realname++; while (pos_realname[0] == ' ') pos_realname++; ptr_channel = channel_search (server, pos_channel); if (ptr_channel && (ptr_channel->checking_away > 0)) { ptr_nick = nick_search (ptr_channel, pos_nick); if (ptr_nick) nick_set_away (ptr_channel, ptr_nick, (pos_attr[0] == 'G') ? 1 : 0); return 0; } irc_display_prefix (server->buffer, PREFIX_SERVER); gui_printf_color (server->buffer, COLOR_WIN_CHAT_NICK, "%s ", pos_nick); gui_printf_color (server->buffer, COLOR_WIN_CHAT, _("on")); gui_printf_color (server->buffer, COLOR_WIN_CHAT_CHANNEL, " %s", pos_channel); gui_printf_color (server->buffer, COLOR_WIN_CHAT, " %s %s ", pos_attr, pos_hopcount); gui_printf_color (server->buffer, COLOR_WIN_CHAT_HOST, "%s@%s", pos_user, pos_host); gui_printf_color (server->buffer, COLOR_WIN_CHAT_DARK, " ("); gui_printf_color (server->buffer, COLOR_WIN_CHAT, "%s", pos_realname); gui_printf_color (server->buffer, COLOR_WIN_CHAT_DARK, ")\n"); } } } } } } } } return 0; } /* * irc_cmd_recv_353: '353' command received (list of users on a channel) */ int irc_cmd_recv_353 (t_irc_server *server, char *host, char *arguments) { char *pos, *pos_nick; int is_chanowner, is_chanadmin, is_op, is_halfop, has_voice; t_irc_channel *ptr_channel; /* make gcc happy */ (void) host; pos = strstr (arguments, " = "); if (pos) arguments = pos + 3; else { pos = strstr (arguments, " * "); if (pos) arguments = pos + 3; else { pos = strstr (arguments, " @ "); if (pos) arguments = pos + 3; } } pos = strchr (arguments, ' '); if (pos) { pos[0] = '\0'; ptr_channel = channel_search (server, arguments); if (!ptr_channel) return 0; pos++; while (pos[0] == ' ') pos++; if (pos[0] != ':') { irc_display_prefix (server->buffer, PREFIX_ERROR); gui_printf_nolog (server->buffer, _("%s cannot parse \"%s\" command\n"), WEECHAT_ERROR, "353"); return -1; } pos++; if (pos[0]) { while (pos && pos[0]) { is_chanowner = 0; is_chanadmin = 0; is_op = 0; is_halfop = 0; has_voice = 0; while ((pos[0] == '@') || (pos[0] == '%') || (pos[0] == '+')) { if (pos[0] == '@') is_op = 1; if (pos[0] == '%') is_halfop = 1; if (pos[0] == '+') has_voice = 1; pos++; } if (pos[0] == '~') { is_chanowner = 1; pos++; } if (pos[0] == '&') { is_chanadmin = 1; pos++; } pos_nick = pos; pos = strchr (pos, ' '); if (pos) { pos[0] = '\0'; pos++; } if (!nick_new (ptr_channel, pos_nick, is_chanowner, is_chanadmin, is_op, is_halfop, has_voice)) { irc_display_prefix (server->buffer, PREFIX_ERROR); gui_printf_nolog (server->buffer, _("%s cannot create nick \"%s\" for channel \"%s\"\n"), WEECHAT_ERROR, pos_nick, ptr_channel->name); } } } gui_draw_buffer_nick (ptr_channel->buffer, 1); gui_draw_buffer_status (ptr_channel->buffer, 1); } else { irc_display_prefix (server->buffer, PREFIX_ERROR); gui_printf_nolog (server->buffer, _("%s cannot parse \"%s\" command\n"), WEECHAT_ERROR, "353"); return -1; } return 0; } /* * irc_cmd_recv_366: '366' command received (end of /names list) */ int irc_cmd_recv_366 (t_irc_server *server, char *host, char *arguments) { char *pos, *pos2; t_irc_channel *ptr_channel; t_irc_nick *ptr_nick; int num_nicks, num_op, num_halfop, num_voice, num_normal; /* make gcc happy */ (void) host; pos = strchr (arguments, ' '); if (pos) { while (pos[0] == ' ') pos++; pos2 = strchr (pos, ' '); if (pos2) { pos2[0] = '\0'; pos2++; while (pos2[0] == ' ') pos2++; if (pos2[0] == ':') pos2++; ptr_channel = channel_search (server, pos); if (ptr_channel) { /* display users on channel */ irc_display_prefix (ptr_channel->buffer, PREFIX_SERVER); gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT, _("Nicks ")); gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT_CHANNEL, "%s", ptr_channel->name); gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT, ": "); gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT_DARK, "["); for (ptr_nick = ptr_channel->nicks; ptr_nick; ptr_nick = ptr_nick->next_nick) { irc_display_nick (ptr_channel->buffer, ptr_nick, MSG_TYPE_MSG, 0, 0, 1); if (ptr_nick != ptr_channel->last_nick) gui_printf (ptr_channel->buffer, " "); } gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT_DARK, "]\n"); /* display number of nicks, ops, halfops & voices on the channel */ nick_count (ptr_channel, &num_nicks, &num_op, &num_halfop, &num_voice, &num_normal); irc_display_prefix (ptr_channel->buffer, PREFIX_INFO); gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT, _("Channel ")); gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT_CHANNEL, "%s", ptr_channel->name); gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT, ": "); gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT_CHANNEL, "%d ", num_nicks); gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT, (num_nicks > 1) ? _("nicks") : _("nick")); gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT_DARK, " ("); gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT_CHANNEL, "%d ", num_op); gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT, (num_op > 1) ? _("ops") : _("op")); gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT, ", "); gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT_CHANNEL, "%d ", num_halfop); gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT, (num_halfop > 1) ? _("halfops") : _("halfop")); gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT, ", "); gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT_CHANNEL, "%d ", num_voice); gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT, (num_voice > 1) ? _("voices") : _("voice")); gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT, ", "); gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT_CHANNEL, "%d ", num_normal); gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT, _("normal")); gui_printf_color (ptr_channel->buffer, COLOR_WIN_CHAT_DARK, ")\n"); irc_cmd_send_mode (server, ptr_channel->name); if (cfg_irc_away_check > 0) channel_check_away (server, ptr_channel); } else { irc_display_prefix (gui_current_window->buffer, PREFIX_INFO); gui_printf_color (gui_current_window->buffer, COLOR_WIN_CHAT_CHANNEL, pos); gui_printf_color (gui_current_window->buffer, COLOR_WIN_CHAT, ": %s\n", pos2); return 0; } } } return 0; } /* * irc_cmd_recv_367: '367' command received (banlist) */ int irc_cmd_recv_367 (t_irc_server *server, char *host, char *arguments) { char *pos_channel, *pos_ban, *pos_user, *pos_date, *pos; t_irc_channel *ptr_channel; t_gui_buffer *buffer; time_t datetime; /* make gcc happy */ (void) host; /* look for channel */ pos_channel = strchr (arguments, ' '); if (!pos_channel) { irc_display_prefix (server->buffer, PREFIX_ERROR); gui_printf_nolog (server->buffer, _("%s cannot parse \"%s\" command\n"), WEECHAT_ERROR, "367"); return -1; } pos_channel[0] = '\0'; pos_channel++; while (pos_channel[0] == ' ') pos_channel++; /* look for ban mask */ pos_ban = strchr (pos_channel, ' '); if (!pos_ban) { irc_display_prefix (server->buffer, PREFIX_ERROR); gui_printf_nolog (server->buffer, _("%s cannot parse \"%s\" command\n"), WEECHAT_ERROR, "367"); return -1; } pos_ban[0] = '\0'; pos_ban++; while (pos_ban[0] == ' ') pos_ban++; /* look for user who set ban */ pos_user = strchr (pos_ban, ' '); if (!pos_user) { irc_display_prefix (server->buffer, PREFIX_ERROR); gui_printf_nolog (server->buffer, _("%s cannot parse \"%s\" command\n"), WEECHAT_ERROR, "367"); return -1; } pos_user[0] = '\0'; pos_user++; while (pos_user[0] == ' ') pos_user++; /* look for date/time */ pos_date = strchr (pos_user, ' '); if (!pos_date) { irc_display_prefix (server->buffer, PREFIX_ERROR); gui_printf_nolog (server->buffer, _("%s cannot parse \"%s\" command\n"), WEECHAT_ERROR, "367"); return -1; } pos_date[0] = '\0'; pos_date++; while (pos_date[0] == ' ') pos_date++; if (!pos_date || !pos_date[0]) { irc_display_prefix (server->buffer, PREFIX_ERROR); gui_printf_nolog (server->buffer, _("%s cannot parse \"%s\" command\n"), WEECHAT_ERROR, "367"); return -1; } ptr_channel = channel_search (server, pos_channel); buffer = (ptr_channel) ? ptr_channel->buffer : server->buffer; irc_display_prefix (buffer, PREFIX_INFO); gui_printf_color (buffer, COLOR_WIN_CHAT_DARK, "["); gui_printf_color (buffer, COLOR_WIN_CHAT_CHANNEL, "%s", pos_channel); gui_printf_color (buffer, COLOR_WIN_CHAT_DARK, "] "); gui_printf_color (buffer, COLOR_WIN_CHAT_HOST, "%s ", pos_ban); gui_printf (buffer, _("banned by")); pos = strchr (pos_user, '!'); if (pos) { pos[0] = '\0'; gui_printf_color (buffer, COLOR_WIN_CHAT_NICK, " %s ", pos_user); gui_printf_color (buffer, COLOR_WIN_CHAT_DARK, "("); gui_printf_color (buffer, COLOR_WIN_CHAT_HOST, "%s", pos + 1); gui_printf_color (buffer, COLOR_WIN_CHAT_DARK, ")"); } else gui_printf_color (buffer, COLOR_WIN_CHAT_NICK, " %s", pos_user); datetime = (time_t)(atol (pos_date)); gui_printf_nolog (buffer, ", %s", ctime (&datetime)); return 0; } /* * irc_cmd_recv_368: '368' command received (end of banlist) */ int irc_cmd_recv_368 (t_irc_server *server, char *host, char *arguments) { char *pos_channel, *pos_msg; t_irc_channel *ptr_channel; t_gui_buffer *buffer; /* make gcc happy */ (void) host; pos_channel = strchr (arguments, ' '); if (!pos_channel) { irc_display_prefix (server->buffer, PREFIX_ERROR); gui_printf_nolog (server->buffer, _("%s cannot parse \"%s\" command\n"), WEECHAT_ERROR, "368"); return -1; } pos_channel[0] = '\0'; pos_channel++; while (pos_channel[0] == ' ') pos_channel++; pos_msg = strchr (pos_channel, ' '); if (!pos_msg) { irc_display_prefix (server->buffer, PREFIX_ERROR); gui_printf_nolog (server->buffer, _("%s cannot parse \"%s\" command\n"), WEECHAT_ERROR, "368"); return -1; } pos_msg[0] = '\0'; pos_msg++; while (pos_msg[0] == ' ') pos_msg++; if (pos_msg[0] == ':') pos_msg++; ptr_channel = channel_search (server, pos_channel); buffer = (ptr_channel) ? ptr_channel->buffer : server->buffer; irc_display_prefix (buffer, PREFIX_INFO); gui_printf_color (buffer, COLOR_WIN_CHAT_DARK, "["); gui_printf_color (buffer, COLOR_WIN_CHAT_CHANNEL, "%s", pos_channel); gui_printf_color (buffer, COLOR_WIN_CHAT_DARK, "] "); gui_printf_nolog (buffer, "%s\n", pos_msg); return 0; } /* * irc_cmd_recv_433: '433' command received (nickname already in use) */ int irc_cmd_recv_433 (t_irc_server *server, char *host, char *arguments) { char hostname[128]; if (!server->is_connected) { if (strcmp (server->nick, server->nick1) == 0) { irc_display_prefix (server->buffer, PREFIX_INFO); gui_printf (server->buffer, _("%s: nickname \"%s\" is already in use, " "trying 2nd nickname \"%s\"\n"), PACKAGE_NAME, server->nick, server->nick2); free (server->nick); server->nick = strdup (server->nick2); } else { if (strcmp (server->nick, server->nick2) == 0) { irc_display_prefix (server->buffer, PREFIX_INFO); gui_printf (server->buffer, _("%s: nickname \"%s\" is already in use, " "trying 3rd nickname \"%s\"\n"), PACKAGE_NAME, server->nick, server->nick3); free (server->nick); server->nick = strdup (server->nick3); } else { if (strcmp (server->nick, server->nick3) == 0) { irc_display_prefix (server->buffer, PREFIX_INFO); gui_printf (server->buffer, _("%s: all declared nicknames are already in use, " "closing connection with server!\n"), PACKAGE_NAME); server_disconnect (server, 1); return 0; } else { irc_display_prefix (server->buffer, PREFIX_INFO); gui_printf (server->buffer, _("%s: nickname \"%s\" is already in use, " "trying 1st nickname \"%s\"\n"), PACKAGE_NAME, server->nick, server->nick1); free (server->nick); server->nick = strdup (server->nick1); } } } gethostname (hostname, sizeof (hostname) - 1); hostname[sizeof (hostname) - 1] = '\0'; if (!hostname[0]) strcpy (hostname, _("unknown")); server_sendf (server, "NICK %s\r\n", server->nick); } else return irc_cmd_recv_error (server, host, arguments); return 0; } /* * irc_cmd_recv_438: '438' command received (not authorized to change nickname) */ int irc_cmd_recv_438 (t_irc_server *server, char *host, char *arguments) { char *pos, *pos2; /* make gcc happy */ (void) server; (void) host; pos = strchr (arguments, ' '); irc_display_prefix (server->buffer, PREFIX_SERVER); if (pos) { pos[0] = '\0'; pos++; pos2 = strstr (pos, " :"); if (pos2) { pos2[0] = '\0'; pos2 += 2; gui_printf (server->buffer, "%s (%s => %s)\n", pos2, arguments, pos); } else gui_printf (server->buffer, "%s (%s)\n", pos, arguments); } else gui_printf (server->buffer, "%s\n", arguments); return 0; } /* * irc_cmd_recv_671: '671' command (whois, secure connection) */ int irc_cmd_recv_671 (t_irc_server *server, char *host, char *arguments) { char *pos_nick, *pos_message; /* make gcc happy */ (void) host; pos_nick = strchr (arguments, ' '); if (pos_nick) { while (pos_nick[0] == ' ') pos_nick++; pos_message = strchr (pos_nick, ' '); if (pos_message) { pos_message[0] = '\0'; pos_message++; while (pos_message[0] == ' ') pos_message++; if (pos_message[0] == ':') pos_message++; irc_display_prefix (server->buffer, PREFIX_SERVER); gui_printf_color (server->buffer, COLOR_WIN_CHAT_DARK, "["); gui_printf_color (server->buffer, COLOR_WIN_CHAT_NICK, "%s", pos_nick); gui_printf_color (server->buffer, COLOR_WIN_CHAT_DARK, "] "); gui_printf_color (server->buffer, COLOR_WIN_CHAT, "%s\n", pos_message); } } return 0; }