diff options
Diffstat (limited to 'protocols/yahoo/yahoo.c')
-rw-r--r-- | protocols/yahoo/yahoo.c | 1024 |
1 files changed, 0 insertions, 1024 deletions
diff --git a/protocols/yahoo/yahoo.c b/protocols/yahoo/yahoo.c deleted file mode 100644 index e7a7e749..00000000 --- a/protocols/yahoo/yahoo.c +++ /dev/null @@ -1,1024 +0,0 @@ -/* - * libyahoo2 wrapper to BitlBee - * - * Mostly Copyright 2004-2012 Wilmer van der Gaast <wilmer@gaast.net> - * - * 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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA - * - */ - - -#include <errno.h> -#include <string.h> -#include <stdlib.h> -#include <stdio.h> -#include <time.h> -#include <sys/stat.h> -#include <ctype.h> -#include "nogaim.h" -#include "yahoo2.h" -#include "yahoo2_callbacks.h" - -#define BYAHOO_DEFAULT_GROUP "Buddies" - -/* A hack to handle removal of buddies not in the group "Buddies" correctly */ -struct byahoo_buddygroups { - char *buddy; - char *group; -}; - -struct byahoo_data { - int y2_id; - int current_status; - gboolean logged_in; - GSList *buddygroups; -}; - -struct byahoo_input_data { - int h; - void *d; -}; - -struct byahoo_conf_invitation { - char *name; - struct groupchat *c; - int yid; - YList *members; - struct im_connection *ic; -}; - -static GSList *byahoo_inputs = NULL; -static int byahoo_chat_id = 0; - -static char *byahoo_strip(const char *in) -{ - int len; - - /* This should get rid of the markup noise at the beginning of the string. */ - while (*in) { - if (g_strncasecmp(in, "<font", 5) == 0 || - g_strncasecmp(in, "<fade", 5) == 0 || - g_strncasecmp(in, "<alt", 4) == 0) { - char *s = strchr(in, '>'); - if (!s) { - break; - } - - in = s + 1; - } else if (strncmp(in, "\e[", 2) == 0) { - const char *s; - - for (s = in + 2; *s && *s != 'm'; s++) { - ; - } - - if (*s != 'm') { - break; - } - - in = s + 1; - } else { - break; - } - } - - /* This is supposed to get rid of the noise at the end of the line. */ - len = strlen(in); - while (len > 0 && (in[len - 1] == '>' || in[len - 1] == 'm')) { - int blen = len; - const char *search; - - if (in[len - 1] == '>') { - search = "</"; - } else { - search = "\e["; - } - - len -= 3; - while (len > 0 && strncmp(in + len, search, 2) != 0) { - len--; - } - - if (len <= 0 && strncmp(in, search, 2) != 0) { - len = blen; - break; - } - } - - return(g_strndup(in, len)); -} - -static void byahoo_init(account_t *acc) -{ - set_t *s; - - s = set_add(&acc->set, "mail_notifications", "false", set_eval_bool, acc); - s->flags |= ACC_SET_OFFLINE_ONLY; - - s = set_add(&acc->set, "mail_notifications_handle", NULL, NULL, acc); - s->flags |= ACC_SET_OFFLINE_ONLY | SET_NULL_OK; - - acc->flags |= ACC_FLAG_AWAY_MESSAGE | ACC_FLAG_STATUS_MESSAGE; -} - -static void byahoo_login(account_t *acc) -{ - struct im_connection *ic = imcb_new(acc); - struct byahoo_data *yd = ic->proto_data = g_new0(struct byahoo_data, 1); - char *s; - - yd->logged_in = FALSE; - yd->current_status = YAHOO_STATUS_AVAILABLE; - - if ((s = strchr(acc->user, '@')) && g_strcasecmp(s, "@yahoo.com") == 0) { - imcb_error(ic, "Your Yahoo! username should just be a username. " - "Do not include any @domain part."); - } - - imcb_log(ic, "Connecting"); - yd->y2_id = yahoo_init(acc->user, acc->pass); - yahoo_login(yd->y2_id, yd->current_status); - - if (set_getbool(&acc->set, "mail_notifications") && set_getstr(&acc->set, "mail_notifications_handle")) { - imcb_add_buddy(ic, set_getstr(&acc->set, "mail_notifications_handle"), NULL); - } -} - -static void byahoo_logout(struct im_connection *ic) -{ - struct byahoo_data *yd = (struct byahoo_data *) ic->proto_data; - GSList *l; - - while (ic->groupchats) { - imcb_chat_free(ic->groupchats->data); - } - - for (l = yd->buddygroups; l; l = l->next) { - struct byahoo_buddygroups *bg = l->data; - - g_free(bg->buddy); - g_free(bg->group); - g_free(bg); - } - g_slist_free(yd->buddygroups); - - yahoo_logoff(yd->y2_id); - - g_free(yd); -} - -static void byahoo_get_info(struct im_connection *ic, char *who) -{ - /* Just make an URL and let the user fetch the info */ - imcb_log(ic, "%s\n%s: %s%s", _("User Info"), - _("For now, fetch yourself"), yahoo_get_profile_url(), - who); -} - -static int byahoo_buddy_msg(struct im_connection *ic, char *who, char *what, int flags) -{ - struct byahoo_data *yd = ic->proto_data; - - yahoo_send_im(yd->y2_id, NULL, who, what, 1, 0); - - return 1; -} - -static int byahoo_send_typing(struct im_connection *ic, char *who, int typing) -{ - struct byahoo_data *yd = ic->proto_data; - - yahoo_send_typing(yd->y2_id, NULL, who, (typing & OPT_TYPING) != 0); - - return 1; -} - -static void byahoo_set_away(struct im_connection *ic, char *state, char *msg) -{ - struct byahoo_data *yd = (struct byahoo_data *) ic->proto_data; - - if (state && msg == NULL) { - /* Use these states only if msg doesn't contain additional - info since away messages are only supported with CUSTOM. */ - if (g_strcasecmp(state, "Be Right Back") == 0) { - yd->current_status = YAHOO_STATUS_BRB; - } else if (g_strcasecmp(state, "Busy") == 0) { - yd->current_status = YAHOO_STATUS_BUSY; - } else if (g_strcasecmp(state, "Not At Home") == 0) { - yd->current_status = YAHOO_STATUS_NOTATHOME; - } else if (g_strcasecmp(state, "Not At Desk") == 0) { - yd->current_status = YAHOO_STATUS_NOTATDESK; - } else if (g_strcasecmp(state, "Not In Office") == 0) { - yd->current_status = YAHOO_STATUS_NOTINOFFICE; - } else if (g_strcasecmp(state, "On Phone") == 0) { - yd->current_status = YAHOO_STATUS_ONPHONE; - } else if (g_strcasecmp(state, "On Vacation") == 0) { - yd->current_status = YAHOO_STATUS_ONVACATION; - } else if (g_strcasecmp(state, "Out To Lunch") == 0) { - yd->current_status = YAHOO_STATUS_OUTTOLUNCH; - } else if (g_strcasecmp(state, "Stepped Out") == 0) { - yd->current_status = YAHOO_STATUS_STEPPEDOUT; - } else if (g_strcasecmp(state, "Invisible") == 0) { - yd->current_status = YAHOO_STATUS_INVISIBLE; - } else { - yd->current_status = YAHOO_STATUS_CUSTOM; - } - } else if (msg) { - yd->current_status = YAHOO_STATUS_CUSTOM; - } else { - yd->current_status = YAHOO_STATUS_AVAILABLE; - } - - yahoo_set_away(yd->y2_id, yd->current_status, msg, state ? 2 : 0); -} - -static GList *byahoo_away_states(struct im_connection *ic) -{ - static GList *m = NULL; - - if (m == NULL) { - m = g_list_append(m, "Be Right Back"); - m = g_list_append(m, "Busy"); - m = g_list_append(m, "Not At Home"); - m = g_list_append(m, "Not At Desk"); - m = g_list_append(m, "Not In Office"); - m = g_list_append(m, "On Phone"); - m = g_list_append(m, "On Vacation"); - m = g_list_append(m, "Out To Lunch"); - m = g_list_append(m, "Stepped Out"); - m = g_list_append(m, "Invisible"); - } - - return m; -} - -static void byahoo_keepalive(struct im_connection *ic) -{ - struct byahoo_data *yd = ic->proto_data; - - yahoo_keepalive(yd->y2_id); -} - -static void byahoo_add_buddy(struct im_connection *ic, char *who, char *group) -{ - struct byahoo_data *yd = (struct byahoo_data *) ic->proto_data; - bee_user_t *bu; - - if (group && (bu = bee_user_by_handle(ic->bee, ic, who)) && bu->group) { - GSList *bgl; - - /* If the person is in our list already, this is a group change. */ - yahoo_change_buddy_group(yd->y2_id, who, bu->group->name, group); - - /* No idea how often people have people in multiple groups and - BitlBee doesn't currently support this anyway .. but keep - this struct up-to-date for now. */ - for (bgl = yd->buddygroups; bgl; bgl = bgl->next) { - struct byahoo_buddygroups *bg = bgl->data; - - if (g_strcasecmp(bg->buddy, who) == 0 && - g_strcasecmp(bg->group, bu->group->name) == 0) { - g_free(bg->group); - bg->group = g_strdup(group); - } - } - } else { - yahoo_add_buddy(yd->y2_id, who, group ? group : BYAHOO_DEFAULT_GROUP, NULL); - } -} - -static void byahoo_remove_buddy(struct im_connection *ic, char *who, char *group) -{ - struct byahoo_data *yd = (struct byahoo_data *) ic->proto_data; - GSList *bgl; - - yahoo_remove_buddy(yd->y2_id, who, BYAHOO_DEFAULT_GROUP); - - for (bgl = yd->buddygroups; bgl; bgl = bgl->next) { - struct byahoo_buddygroups *bg = bgl->data; - - if (g_strcasecmp(bg->buddy, who) == 0) { - yahoo_remove_buddy(yd->y2_id, who, bg->group); - } - } -} - -static void byahoo_chat_msg(struct groupchat *c, char *message, int flags) -{ - struct byahoo_data *yd = (struct byahoo_data *) c->ic->proto_data; - - yahoo_conference_message(yd->y2_id, NULL, c->data, c->title, message, 1); -} - -static void byahoo_chat_invite(struct groupchat *c, char *who, char *msg) -{ - struct byahoo_data *yd = (struct byahoo_data *) c->ic->proto_data; - - yahoo_conference_invite(yd->y2_id, NULL, c->data, c->title, msg ? msg : ""); -} - -static void byahoo_chat_leave(struct groupchat *c) -{ - struct byahoo_data *yd = (struct byahoo_data *) c->ic->proto_data; - - yahoo_conference_logoff(yd->y2_id, NULL, c->data, c->title); - imcb_chat_free(c); -} - -static struct groupchat *byahoo_chat_with(struct im_connection *ic, char *who) -{ - struct byahoo_data *yd = (struct byahoo_data *) ic->proto_data; - struct groupchat *c; - char *roomname; - YList *members; - - roomname = g_strdup_printf("%s-Bee-%d", ic->acc->user, byahoo_chat_id); - - c = imcb_chat_new(ic, roomname); - imcb_chat_add_buddy(c, ic->acc->user); - - /* FIXME: Free this thing when the chat's destroyed. We can't *always* - do this because it's not always created here. */ - c->data = members = g_new0(YList, 1); - members->data = g_strdup(who); - - yahoo_conference_invite(yd->y2_id, NULL, members, roomname, "Please join my groupchat..."); - - g_free(roomname); - - return c; -} - -static void byahoo_auth_allow(struct im_connection *ic, const char *who) -{ - struct byahoo_data *yd = (struct byahoo_data *) ic->proto_data; - - yahoo_confirm_buddy(yd->y2_id, who, 0, ""); -} - -static void byahoo_auth_deny(struct im_connection *ic, const char *who) -{ - struct byahoo_data *yd = (struct byahoo_data *) ic->proto_data; - - yahoo_confirm_buddy(yd->y2_id, who, 1, ""); -} - -void byahoo_initmodule() -{ - struct prpl *ret = g_new0(struct prpl, 1); - - ret->name = "yahoo"; - ret->mms = 832; /* this guess taken from libotr UPGRADING file */ - ret->init = byahoo_init; - - ret->login = byahoo_login; - ret->keepalive = byahoo_keepalive; - ret->logout = byahoo_logout; - - ret->buddy_msg = byahoo_buddy_msg; - ret->get_info = byahoo_get_info; - ret->away_states = byahoo_away_states; - ret->set_away = byahoo_set_away; - ret->add_buddy = byahoo_add_buddy; - ret->remove_buddy = byahoo_remove_buddy; - ret->send_typing = byahoo_send_typing; - - ret->chat_msg = byahoo_chat_msg; - ret->chat_invite = byahoo_chat_invite; - ret->chat_leave = byahoo_chat_leave; - ret->chat_with = byahoo_chat_with; - - ret->handle_cmp = g_strcasecmp; - - ret->auth_allow = byahoo_auth_allow; - ret->auth_deny = byahoo_auth_deny; - - register_protocol(ret); -} - -static struct im_connection *byahoo_get_ic_by_id(int id) -{ - GSList *l; - struct im_connection *ic; - struct byahoo_data *yd; - - for (l = get_connections(); l; l = l->next) { - ic = l->data; - yd = ic->proto_data; - - if (strcmp(ic->acc->prpl->name, "yahoo") == 0 && yd->y2_id == id) { - return(ic); - } - } - - return(NULL); -} - - -/* Now it's callback time! */ - -struct byahoo_connect_callback_data { - int fd; - yahoo_connect_callback callback; - gpointer data; - int id; -}; - -void byahoo_connect_callback(gpointer data, gint source, b_input_condition cond) -{ - struct byahoo_connect_callback_data *d = data; - struct im_connection *ic; - - if (!(ic = byahoo_get_ic_by_id(d->id))) { - g_free(d); - return; - } - - if (source == -1) { - d->callback(NULL, 0, d->data); - imcb_error(ic, "Could not connect to server"); - imc_logout(ic, TRUE); - g_free(d); - return; - } - - d->callback(NULL + d->fd, 0, d->data); - g_free(d); -} - -struct byahoo_read_ready_data { - int id; - int fd; - int tag; - gpointer data; -}; - -gboolean byahoo_read_ready_callback(gpointer data, gint source, b_input_condition cond) -{ - struct byahoo_read_ready_data *d = data; - - if (!byahoo_get_ic_by_id(d->id)) { - /* WTF doesn't libyahoo clean this up? */ - return FALSE; - } - - yahoo_read_ready(d->id, NULL + d->fd, d->data); - - return TRUE; -} - -struct byahoo_write_ready_data { - int id; - int fd; - int tag; - gpointer data; -}; - -gboolean byahoo_write_ready_callback(gpointer data, gint source, b_input_condition cond) -{ - struct byahoo_write_ready_data *d = data; - - return yahoo_write_ready(d->id, NULL + d->fd, d->data); -} - -void ext_yahoo_login_response(int id, int succ, const char *url) -{ - struct im_connection *ic = byahoo_get_ic_by_id(id); - struct byahoo_data *yd = NULL; - - if (ic == NULL) { - /* libyahoo2 seems to call this one twice when something - went wrong sometimes. Don't know why. Because we clean - up the connection on the first failure, the second - should be ignored. */ - - return; - } - - yd = (struct byahoo_data *) ic->proto_data; - - if (succ == YAHOO_LOGIN_OK) { - imcb_connected(ic); - - yd->logged_in = TRUE; - } else { - char *errstr; - int allow_reconnect = FALSE; - - yd->logged_in = FALSE; - - if (succ == YAHOO_LOGIN_UNAME) { - errstr = "Incorrect Yahoo! username"; - } else if (succ == YAHOO_LOGIN_PASSWD) { - errstr = "Incorrect Yahoo! password"; - } else if (succ == YAHOO_LOGIN_LOCK) { - errstr = "Yahoo! account locked"; - } else if (succ == 1236) { - errstr = "Yahoo! account locked or machine temporarily banned"; - } else if (succ == YAHOO_LOGIN_DUPL) { - errstr = "Logged in on a different machine or device"; - } else if (succ == YAHOO_LOGIN_SOCK) { - errstr = "Socket problem"; - allow_reconnect = TRUE; - } else { - errstr = "Unknown error"; - } - - if (url && *url) { - imcb_error(ic, "Error %d (%s). See %s for more information.", succ, errstr, url); - } else { - imcb_error(ic, "Error %d (%s)", succ, errstr); - } - - imc_logout(ic, allow_reconnect); - } -} - -void ext_yahoo_got_buddies(int id, YList *buds) -{ - struct im_connection *ic = byahoo_get_ic_by_id(id); - struct byahoo_data *yd = ic->proto_data; - YList *bl = buds; - - while (bl) { - struct yahoo_buddy *b = bl->data; - struct byahoo_buddygroups *bg; - - if (strcmp(b->group, BYAHOO_DEFAULT_GROUP) != 0) { - bg = g_new0(struct byahoo_buddygroups, 1); - - bg->buddy = g_strdup(b->id); - bg->group = g_strdup(b->group); - yd->buddygroups = g_slist_append(yd->buddygroups, bg); - } - - imcb_add_buddy(ic, b->id, b->group); - imcb_rename_buddy(ic, b->id, b->real_name); - - bl = bl->next; - } -} - -void ext_yahoo_got_identities(int id, YList *ids) -{ -} - -void ext_yahoo_got_cookies(int id) -{ -} - -void ext_yahoo_status_changed(int id, const char *who, int stat, const char *msg, int away, int idle, int mobile) -{ - struct im_connection *ic = byahoo_get_ic_by_id(id); - char *state_string = NULL; - int flags = OPT_LOGGED_IN; - - if (away) { - flags |= OPT_AWAY; - } - if (mobile) { - flags |= OPT_MOBILE; - } - - switch (stat) { - case YAHOO_STATUS_BRB: - state_string = "Be Right Back"; - break; - case YAHOO_STATUS_BUSY: - state_string = "Busy"; - break; - case YAHOO_STATUS_NOTATHOME: - state_string = "Not At Home"; - break; - case YAHOO_STATUS_NOTATDESK: - state_string = "Not At Desk"; - break; - case YAHOO_STATUS_NOTINOFFICE: - state_string = "Not In Office"; - break; - case YAHOO_STATUS_ONPHONE: - state_string = "On Phone"; - break; - case YAHOO_STATUS_ONVACATION: - state_string = "On Vacation"; - break; - case YAHOO_STATUS_OUTTOLUNCH: - state_string = "Out To Lunch"; - break; - case YAHOO_STATUS_STEPPEDOUT: - state_string = "Stepped Out"; - break; - case YAHOO_STATUS_INVISIBLE: - state_string = "Invisible"; - break; - case YAHOO_STATUS_CUSTOM: - state_string = "Away"; - break; - case YAHOO_STATUS_IDLE: - state_string = "Idle"; - break; - case YAHOO_STATUS_OFFLINE: - state_string = "Offline"; - flags = 0; - break; - } - - imcb_buddy_status(ic, who, flags, state_string, msg); - - if (stat == YAHOO_STATUS_IDLE) { - imcb_buddy_times(ic, who, 0, idle); - } -} - -void ext_yahoo_got_buzz(int id, const char *me, const char *who, long tm) -{ -} - -void ext_yahoo_got_im(int id, const char *me, const char *who, const char *msg, long tm, int stat, int utf8) -{ - struct im_connection *ic = byahoo_get_ic_by_id(id); - char *m; - - if (msg) { - m = byahoo_strip(msg); - imcb_buddy_msg(ic, (char *) who, (char *) m, 0, 0); - g_free(m); - } -} - -void ext_yahoo_got_file(int id, const char *ignored, const char *who, const char *msg, - const char *fname, unsigned long fesize, char *trid) -{ - struct im_connection *ic = byahoo_get_ic_by_id(id); - - imcb_log(ic, "Got a file transfer (file = %s) from %s. Ignoring for now due to lack of support.", fname, who); -} - -void ext_yahoo_got_ft_data(int id, const unsigned char *in, int len, void *data) -{ -} - -void ext_yahoo_file_transfer_done(int id, int result, void *data) -{ -} - -void ext_yahoo_typing_notify(int id, const char *ignored, const char *who, int stat) -{ - struct im_connection *ic = byahoo_get_ic_by_id(id); - - if (stat == 1) { - imcb_buddy_typing(ic, (char *) who, OPT_TYPING); - } else { - imcb_buddy_typing(ic, (char *) who, 0); - } -} - -void ext_yahoo_system_message(int id, const char *me, const char *who, const char *msg) -{ - struct im_connection *ic = byahoo_get_ic_by_id(id); - - imcb_log(ic, "Yahoo! system message: %s", msg); -} - -void ext_yahoo_webcam_invite(int id, const char *ignored, const char *from) -{ - struct im_connection *ic = byahoo_get_ic_by_id(id); - - imcb_log(ic, "Got a webcam invitation from %s. IRC+webcams is a no-no though...", from); -} - -void ext_yahoo_error(int id, const char *err, int fatal, int num) -{ - struct im_connection *ic = byahoo_get_ic_by_id(id); - - imcb_error(ic, "%s", err); -} - -/* TODO: Clear up the mess of inp and d structures */ -int ext_yahoo_add_handler(int id, void *fd_, yahoo_input_condition cond, void *data) -{ - struct byahoo_input_data *inp = g_new0(struct byahoo_input_data, 1); - int fd = (long) fd_; - - if (cond == YAHOO_INPUT_READ) { - struct byahoo_read_ready_data *d = g_new0(struct byahoo_read_ready_data, 1); - - d->id = id; - d->fd = fd; - d->data = data; - - inp->d = d; - d->tag = inp->h = b_input_add(fd, B_EV_IO_READ, (b_event_handler) byahoo_read_ready_callback, - (gpointer) d); - } else if (cond == YAHOO_INPUT_WRITE) { - struct byahoo_write_ready_data *d = g_new0(struct byahoo_write_ready_data, 1); - - d->id = id; - d->fd = fd; - d->data = data; - - inp->d = d; - d->tag = inp->h = - b_input_add(fd, B_EV_IO_WRITE, (b_event_handler) byahoo_write_ready_callback, - (gpointer) d); - } else { - g_free(inp); - return -1; - /* Panic... */ - } - - byahoo_inputs = g_slist_append(byahoo_inputs, inp); - return inp->h; -} - -void ext_yahoo_remove_handler(int id, int tag) -{ - struct byahoo_input_data *inp; - GSList *l = byahoo_inputs; - - while (l) { - inp = l->data; - if (inp->h == tag) { - byahoo_inputs = g_slist_remove(byahoo_inputs, inp); - g_free(inp->d); - g_free(inp); - break; - } - l = l->next; - } - - b_event_remove(tag); -} - -int ext_yahoo_connect_async(int id, const char *host, int port, yahoo_connect_callback callback, void *data, - int use_ssl) -{ - struct byahoo_connect_callback_data *d; - int fd; - - d = g_new0(struct byahoo_connect_callback_data, 1); - if ((fd = proxy_connect(host, port, (b_event_handler) byahoo_connect_callback, (gpointer) d)) < 0) { - g_free(d); - return(fd); - } - d->fd = fd; - d->callback = callback; - d->data = data; - d->id = id; - - return fd; -} - -char *ext_yahoo_get_ip_addr(const char *domain) -{ - return NULL; -} - -int ext_yahoo_write(void *fd, char *buf, int len) -{ - return write((long) fd, buf, len); -} - -int ext_yahoo_read(void *fd, char *buf, int len) -{ - return read((long) fd, buf, len); -} - -void ext_yahoo_close(void *fd) -{ - close((long) fd); -} - -void ext_yahoo_got_buddy_change_group(int id, const char *me, const char *who, - const char *old_group, const char *new_group) -{ - struct im_connection *ic = byahoo_get_ic_by_id(id); - - imcb_add_buddy(ic, who, new_group); -} - -static void byahoo_accept_conf(void *data) -{ - struct byahoo_conf_invitation *inv = data; - struct groupchat *b = NULL; - GSList *l; - - for (l = inv->ic->groupchats; l; l = l->next) { - b = l->data; - if (b == inv->c) { - break; - } - } - - if (b != NULL) { - yahoo_conference_logon(inv->yid, NULL, inv->members, inv->name); - imcb_chat_add_buddy(inv->c, inv->ic->acc->user); - } else { - imcb_log(inv->ic, "Duplicate/corrupted invitation to `%s'.", inv->name); - } - - g_free(inv->name); - g_free(inv); -} - -static void byahoo_reject_conf(void *data) -{ - struct byahoo_conf_invitation *inv = data; - - yahoo_conference_decline(inv->yid, NULL, inv->members, inv->name, "User rejected groupchat"); - imcb_chat_free(inv->c); - g_free(inv->name); - g_free(inv); -} - -void ext_yahoo_got_conf_invite(int id, const char *ignored, - const char *who, const char *room, const char *msg, YList *members) -{ - struct im_connection *ic = byahoo_get_ic_by_id(id); - struct byahoo_conf_invitation *inv; - char txt[1024]; - YList *m; - - if (g_strcasecmp(who, ic->acc->user) == 0) { - /* WTF, Yahoo! seems to echo these now? */ - return; - } - - inv = g_malloc(sizeof(struct byahoo_conf_invitation)); - memset(inv, 0, sizeof(struct byahoo_conf_invitation)); - inv->name = g_strdup(room); - inv->c = imcb_chat_new(ic, (char *) room); - inv->c->data = members; - inv->yid = id; - inv->members = members; - inv->ic = ic; - - for (m = members; m; m = m->next) { - if (g_strcasecmp(m->data, ic->acc->user) != 0) { - imcb_chat_add_buddy(inv->c, m->data); - } - } - - g_snprintf(txt, 1024, "Got an invitation to chatroom %s from %s: %s", room, who, msg); - - imcb_ask(ic, txt, inv, byahoo_accept_conf, byahoo_reject_conf); -} - -void ext_yahoo_conf_userdecline(int id, const char *ignored, const char *who, const char *room, const char *msg) -{ - struct im_connection *ic = byahoo_get_ic_by_id(id); - - imcb_log(ic, "Invite to chatroom %s rejected by %s: %s", room, who, msg); -} - -void ext_yahoo_conf_userjoin(int id, const char *ignored, const char *who, const char *room) -{ - struct im_connection *ic = byahoo_get_ic_by_id(id); - struct groupchat *c = bee_chat_by_title(ic->bee, ic, room); - - if (c) { - imcb_chat_add_buddy(c, (char *) who); - } -} - -void ext_yahoo_conf_userleave(int id, const char *ignored, const char *who, const char *room) - -{ - struct im_connection *ic = byahoo_get_ic_by_id(id); - struct groupchat *c = bee_chat_by_title(ic->bee, ic, room); - - if (c) { - imcb_chat_remove_buddy(c, (char *) who, ""); - } -} - -void ext_yahoo_conf_message(int id, const char *ignored, const char *who, const char *room, const char *msg, int utf8) -{ - struct im_connection *ic = byahoo_get_ic_by_id(id); - char *m = byahoo_strip(msg); - struct groupchat *c = bee_chat_by_title(ic->bee, ic, room); - - if (c) { - imcb_chat_msg(c, (char *) who, (char *) m, 0, 0); - } - g_free(m); -} - -void ext_yahoo_chat_cat_xml(int id, const char *xml) -{ -} - -void ext_yahoo_chat_join(int id, const char *who, const char *room, const char *topic, YList *members, void *fd) -{ -} - -void ext_yahoo_chat_userjoin(int id, const char *me, const char *room, struct yahoo_chat_member *who) -{ - free(who->id); - free(who->alias); - free(who->location); - free(who); -} - -void ext_yahoo_chat_userleave(int id, const char *me, const char *room, const char *who) -{ -} - -void ext_yahoo_chat_message(int id, const char *me, const char *who, const char *room, const char *msg, int msgtype, - int utf8) -{ -} - -void ext_yahoo_chat_yahoologout(int id, const char *me) -{ -} - -void ext_yahoo_chat_yahooerror(int id, const char *me) -{ -} - -void ext_yahoo_contact_added(int id, const char *myid, const char *who, const char *msg) -{ - struct im_connection *ic = byahoo_get_ic_by_id(id); - - imcb_ask_auth(ic, who, msg); -} - -void ext_yahoo_rejected(int id, const char *who, const char *msg) -{ -} - -void ext_yahoo_game_notify(int id, const char *me, const char *who, int stat, const char *msg) -{ -} - -void ext_yahoo_mail_notify(int id, const char *from, const char *subj, int cnt) -{ - struct im_connection *ic = byahoo_get_ic_by_id(id); - - if (from && subj) { - imcb_notify_email(ic, "Received e-mail message from %s with subject `%s'", from, subj); - } else if (cnt > 0) { - imcb_notify_email(ic, "Received %d new e-mails", cnt); - } -} - -void ext_yahoo_webcam_invite_reply(int id, const char *me, const char *from, int accept) -{ -} - -void ext_yahoo_webcam_closed(int id, const char *who, int reason) -{ -} - -void ext_yahoo_got_search_result(int id, int found, int start, int total, YList *contacts) -{ -} - -void ext_yahoo_webcam_viewer(int id, const char *who, int connect) -{ -} - -void ext_yahoo_webcam_data_request(int id, int send) -{ -} - -int ext_yahoo_log(const char *fmt, ...) -{ - return(0); -} - -void ext_yahoo_got_webcam_image(int id, const char * who, const unsigned char *image, unsigned int image_size, - unsigned int real_size, unsigned int timestamp) -{ -} - -void ext_yahoo_got_ping(int id, const char *msg) -{ -} - -void ext_yahoo_got_buddyicon(int id, const char *me, const char *who, const char *url, int checksum) -{ -} -void ext_yahoo_got_buddyicon_checksum(int id, const char *me, const char *who, int checksum) -{ -} - -void ext_yahoo_got_buddyicon_request(int id, const char *me, const char *who) -{ -} -void ext_yahoo_buddyicon_uploaded(int id, const char *url) -{ -} |