aboutsummaryrefslogtreecommitdiffstats
path: root/protocols/yahoo/yahoo.c
diff options
context:
space:
mode:
Diffstat (limited to 'protocols/yahoo/yahoo.c')
-rw-r--r--protocols/yahoo/yahoo.c1024
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)
-{
-}