Mercurial > pidgin
view src/protocols/msn/session.c @ 8483:8d3dd39e89ee
[gaim-migrate @ 9216]
credit where credit is due
committer: Tailor Script <tailor@pidgin.im>
author | Luke Schierer <lschiere@pidgin.im> |
---|---|
date | Mon, 22 Mar 2004 05:19:06 +0000 |
parents | 06f57183e29f |
children | 467b01d02f9c |
line wrap: on
line source
/** * @file session.c MSN session functions * * gaim * * Copyright (C) 2003-2004 Christian Hammond <chipx86@gnupdate.org> * * 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 */ #include "msn.h" #include "session.h" #include "dispatch.h" #include "notification.h" MsnSession * msn_session_new(GaimAccount *account, const char *server, int port) { MsnSession *session; g_return_val_if_fail(account != NULL, NULL); session = g_new0(MsnSession, 1); session->account = account; session->dispatch_server = g_strdup(server); session->dispatch_port = port; session->away_state = NULL; session->users = msn_users_new(); session->groups = msn_groups_new(); #ifdef HAVE_SSL session->protocol_ver = 9; #else session->protocol_ver = 7; #endif return session; } void msn_session_destroy(MsnSession *session) { g_return_if_fail(session != NULL); if (session->connected) msn_session_disconnect(session); if (session->dispatch_server != NULL) g_free(session->dispatch_server); while (session->switches != NULL) msn_switchboard_destroy(session->switches->data); while (session->lists.forward) msn_user_destroy(session->lists.forward->data); if (session->lists.allow != NULL) g_slist_free(session->lists.allow); if (session->lists.block != NULL) g_slist_free(session->lists.block); msn_groups_destroy(session->groups); msn_users_destroy(session->users); if (session->passport_info.kv != NULL) g_free(session->passport_info.kv); if (session->passport_info.sid != NULL) g_free(session->passport_info.sid); if (session->passport_info.mspauth != NULL) g_free(session->passport_info.mspauth); if (session->passport_info.file != NULL) g_free(session->passport_info.file); if (session->away_state != NULL) g_free(session->away_state); if (session->nexus != NULL) msn_nexus_destroy(session->nexus); g_free(session); } gboolean msn_session_connect(MsnSession *session) { g_return_val_if_fail(session != NULL, FALSE); g_return_val_if_fail(!session->connected, TRUE); session->connected = TRUE; if (session->http_method) { session->notification_conn = msn_notification_new(session, "gateway.messenger.hotmail.com", 80); if (msn_servconn_connect(session->notification_conn)) return TRUE; } else { session->dispatch_conn = msn_dispatch_new(session, session->dispatch_server, session->dispatch_port); if (msn_servconn_connect(session->dispatch_conn)) return TRUE; } return FALSE; } void msn_session_disconnect(MsnSession *session) { g_return_if_fail(session != NULL); g_return_if_fail(session->connected); if (session->dispatch_conn != NULL) { msn_servconn_destroy(session->dispatch_conn); session->dispatch_conn = NULL; } while (session->switches != NULL) { MsnSwitchBoard *board = (MsnSwitchBoard *)session->switches->data; msn_switchboard_destroy(board); } if (session->notification_conn != NULL) { msn_servconn_destroy(session->notification_conn); session->notification_conn = NULL; } } MsnSwitchBoard * msn_session_open_switchboard(MsnSession *session) { MsnSwitchBoard *swboard; g_return_val_if_fail(session != NULL, NULL); if (msn_servconn_send_command(session->notification_conn, "XFR", "SB") < 0) { return NULL; } swboard = msn_switchboard_new(session); return swboard; } gboolean msn_session_change_status(MsnSession *session, const char *state) { MsnUser *user = session->user; MsnObject *msnobj; char buf[MSN_BUF_LEN]; g_return_val_if_fail(session != NULL, FALSE); g_return_val_if_fail(state != NULL, FALSE); msnobj = msn_user_get_object(user); if (state != session->away_state) { if (session->away_state != NULL) g_free(session->away_state); session->away_state = g_strdup(state); } if (msnobj == NULL) g_snprintf(buf, sizeof(buf), "%s %d", state, MSN_CLIENT_ID); else { char *msnobj_str = msn_object_to_string(msnobj); g_snprintf(buf, sizeof(buf), "%s %d %s", state, MSN_CLIENT_ID, gaim_url_encode(msnobj_str)); g_free(msnobj_str); } if (!msn_servconn_send_command(session->notification_conn, "CHG", buf)) { gaim_connection_error(gaim_account_get_connection(session->account), _("Write error")); return FALSE; } return TRUE; } MsnSwitchBoard * msn_session_find_switch_with_passport(const MsnSession *session, const char *passport) { GList *l; MsnSwitchBoard *swboard; g_return_val_if_fail(session != NULL, NULL); g_return_val_if_fail(passport != NULL, NULL); for (l = session->switches; l != NULL; l = l->next) { swboard = (MsnSwitchBoard *)l->data; if (!swboard->hidden && !g_ascii_strcasecmp(passport, msn_user_get_passport(swboard->user))) { return swboard; } } return NULL; } MsnSwitchBoard * msn_session_find_switch_with_id(const MsnSession *session, int chat_id) { GList *l; MsnSwitchBoard *swboard; g_return_val_if_fail(session != NULL, NULL); g_return_val_if_fail(chat_id > 0, NULL); for (l = session->switches; l != NULL; l = l->next) { swboard = (MsnSwitchBoard *)l->data; if (swboard->chat_id == chat_id) return swboard; } return NULL; } MsnSwitchBoard * msn_session_find_unused_switch(const MsnSession *session) { GList *l; MsnSwitchBoard *swboard; g_return_val_if_fail(session != NULL, NULL); for (l = session->switches; l != NULL; l = l->next) { swboard = (MsnSwitchBoard *)l->data; if (!swboard->in_use) return swboard; } return NULL; }