Wed, 05 Sep 2007 22:33:22 +0000
Patch from QuLogic. Fixes #2903 ('Missing newlines in debug messages.')
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1 | /* MySpaceIM Protocol Plugin |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3 | * \author Jeff Connelly |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
4 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
5 | * Copyright (C) 2007, Jeff Connelly <jeff2@soc.pidgin.im> |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
6 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
7 | * Based on Purple's "C Plugin HOWTO" hello world example. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
8 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
9 | * Code also drawn from mockprpl: |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
10 | * http://snarfed.org/space/purple+mock+protocol+plugin |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
11 | * Copyright (C) 2004-2007, Ryan Barrett <mockprpl@ryanb.org> |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
12 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
13 | * and some constructs also based on existing Purple plugins, which are: |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
14 | * Copyright (C) 2003, Robbert Haarman <purple@inglorion.net> |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
15 | * Copyright (C) 2003, Ethan Blanton <eblanton@cs.purdue.edu> |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
16 | * Copyright (C) 2000-2003, Rob Flynn <rob@tgflinux.com> |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
17 | * Copyright (C) 1998-1999, Mark Spencer <markster@marko.net> |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
18 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
19 | * This program is free software; you can redistribute it and/or modify |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
20 | * it under the terms of the GNU General Public License as published by |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
21 | * the Free Software Foundation; either version 2 of the License, or |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
22 | * (at your option) any later version. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
23 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
24 | * This program is distributed in the hope that it will be useful, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
25 | * but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
26 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
27 | * GNU General Public License for more details. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
28 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
29 | * You should have received a copy of the GNU General Public License |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
30 | * along with this program; if not, write to the Free Software |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
31 | * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
32 | */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
33 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
34 | #define PURPLE_PLUGIN |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
35 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
36 | #include "myspace.h" |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
37 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
38 | /* Internal functions */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
39 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
40 | #ifdef MSIM_DEBUG_MSG |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
41 | static void print_hash_item(gpointer key, gpointer value, gpointer user_data); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
42 | #endif |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
43 | |
|
19619
e9ac2df3fd1b
In msimprpl, move user-related code to a new user module, and move other
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19618
diff
changeset
|
44 | static int msim_send_really_raw(PurpleConnection *gc, const char *buf, int total_bytes); |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
45 | static gboolean msim_login_challenge(MsimSession *session, MsimMessage *msg); |
|
19619
e9ac2df3fd1b
In msimprpl, move user-related code to a new user module, and move other
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19618
diff
changeset
|
46 | static const gchar *msim_compute_login_response(const gchar nonce[2 * NONCE_SIZE], const gchar *email, const gchar *password, guint *response_len); |
|
e9ac2df3fd1b
In msimprpl, move user-related code to a new user module, and move other
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19618
diff
changeset
|
47 | |
|
e9ac2df3fd1b
In msimprpl, move user-related code to a new user module, and move other
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19618
diff
changeset
|
48 | static gboolean msim_incoming_bm_record_cv(MsimSession *session, MsimMessage *msg); |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
49 | static gboolean msim_incoming_bm(MsimSession *session, MsimMessage *msg); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
50 | static gboolean msim_incoming_status(MsimSession *session, MsimMessage *msg); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
51 | static gboolean msim_incoming_im(MsimSession *session, MsimMessage *msg); |
|
19616
017838ce7393
In msimprpl, move zap-related code to a separate module.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19615
diff
changeset
|
52 | /* static gboolean msim_incoming_zap(MsimSession *session, MsimMessage *msg); - in zap.c */ |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
53 | static gboolean msim_incoming_action(MsimSession *session, MsimMessage *msg); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
54 | static gboolean msim_incoming_media(MsimSession *session, MsimMessage *msg); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
55 | static gboolean msim_incoming_unofficial_client(MsimSession *session, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
56 | MsimMessage *msg); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
57 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
58 | #ifdef MSIM_SEND_CLIENT_VERSION |
|
19619
e9ac2df3fd1b
In msimprpl, move user-related code to a new user module, and move other
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19618
diff
changeset
|
59 | static gboolean msim_send_unofficial_client(MsimSession *session, gchar *username); |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
60 | #endif |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
61 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
62 | static void msim_get_info_cb(MsimSession *session, MsimMessage *userinfo, gpointer data); |
|
19619
e9ac2df3fd1b
In msimprpl, move user-related code to a new user module, and move other
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19618
diff
changeset
|
63 | |
|
e9ac2df3fd1b
In msimprpl, move user-related code to a new user module, and move other
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19618
diff
changeset
|
64 | static void msim_set_status_code(MsimSession *session, guint code, gchar *statstring); |
|
e9ac2df3fd1b
In msimprpl, move user-related code to a new user module, and move other
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19618
diff
changeset
|
65 | |
|
e9ac2df3fd1b
In msimprpl, move user-related code to a new user module, and move other
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19618
diff
changeset
|
66 | static gboolean msim_process_server_info(MsimSession *session, MsimMessage *msg); |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
67 | static gboolean msim_web_challenge(MsimSession *session, MsimMessage *msg); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
68 | static gboolean msim_process_reply(MsimSession *session, MsimMessage *msg); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
69 | |
|
19518
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
70 | static gboolean msim_preprocess_incoming(MsimSession *session, MsimMessage *msg); |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
71 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
72 | #ifdef MSIM_USE_KEEPALIVE |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
73 | static gboolean msim_check_alive(gpointer data); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
74 | #endif |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
75 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
76 | static gboolean msim_we_are_logged_on(MsimSession *session, MsimMessage *msg); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
77 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
78 | static gboolean msim_process(MsimSession *session, MsimMessage *msg); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
79 | |
|
19619
e9ac2df3fd1b
In msimprpl, move user-related code to a new user module, and move other
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19618
diff
changeset
|
80 | static MsimMessage *msim_do_postprocessing(MsimMessage *msg, const gchar *uid_field_name, const gchar *uid_before, guint uid); |
|
e9ac2df3fd1b
In msimprpl, move user-related code to a new user module, and move other
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19618
diff
changeset
|
81 | static void msim_postprocess_outgoing_cb(MsimSession *session, MsimMessage *userinfo, gpointer data); |
|
e9ac2df3fd1b
In msimprpl, move user-related code to a new user module, and move other
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19618
diff
changeset
|
82 | static gboolean msim_postprocess_outgoing(MsimSession *session, MsimMessage *msg, const gchar *username, const gchar *uid_field_name, const gchar *uid_before); |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
83 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
84 | static gboolean msim_error(MsimSession *session, MsimMessage *msg); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
85 | |
|
19619
e9ac2df3fd1b
In msimprpl, move user-related code to a new user module, and move other
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19618
diff
changeset
|
86 | static void msim_check_inbox_cb(MsimSession *session, MsimMessage *userinfo, gpointer data); |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
87 | static gboolean msim_check_inbox(gpointer data); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
88 | |
|
19619
e9ac2df3fd1b
In msimprpl, move user-related code to a new user module, and move other
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19618
diff
changeset
|
89 | static void msim_input_cb(gpointer gc_uncasted, gint source, PurpleInputCondition cond); |
|
e9ac2df3fd1b
In msimprpl, move user-related code to a new user module, and move other
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19618
diff
changeset
|
90 | |
|
e9ac2df3fd1b
In msimprpl, move user-related code to a new user module, and move other
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19618
diff
changeset
|
91 | |
|
e9ac2df3fd1b
In msimprpl, move user-related code to a new user module, and move other
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19618
diff
changeset
|
92 | static void msim_connect_cb(gpointer data, gint source, const gchar *error_message); |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
93 | |
|
19512
040a04d43bbb
First half of "Add friends from MySpace.com" support: add msim_import_friends(),
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19510
diff
changeset
|
94 | static void msim_import_friends(PurplePluginAction *action); |
|
19640
48e64a5069da
On login, get contacts from server using msim_get_contact_list().
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19634
diff
changeset
|
95 | static void msim_import_friends_cb(MsimSession *session, MsimMessage *reply, gpointer user_data); |
|
48e64a5069da
On login, get contacts from server using msim_get_contact_list().
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19634
diff
changeset
|
96 | static gboolean msim_get_contact_list(MsimSession *session, int what_to_do_after); |
|
19512
040a04d43bbb
First half of "Add friends from MySpace.com" support: add msim_import_friends(),
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19510
diff
changeset
|
97 | |
|
19633
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
98 | static gboolean msim_uri_handler(const gchar *proto, const gchar *cmd, GHashTable *params); |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
99 | static void msim_uri_handler_addContact_cb(MsimSession *session, MsimMessage *userinfo, gpointer data); |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
100 | static void msim_uri_handler_sendIM_cb(MsimSession *session, MsimMessage *userinfo, gpointer data); |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
101 | |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
102 | /** |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
103 | * Load the plugin. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
104 | */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
105 | gboolean |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
106 | msim_load(PurplePlugin *plugin) |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
107 | { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
108 | /* If compiled to use RC4 from libpurple, check if it is really there. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
109 | if (!purple_ciphers_find_cipher("rc4")) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
110 | purple_debug_error("msim", "rc4 not in libpurple, but it is required - not loading MySpaceIM plugin!\n"); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
111 | purple_notify_error(plugin, _("Missing Cipher"), |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
112 | _("The RC4 cipher could not be found"), |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
113 | _("Upgrade " |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
114 | "to a libpurple with RC4 support (>= 2.0.1). MySpaceIM " |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
115 | "plugin will not be loaded.")); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
116 | return FALSE; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
117 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
118 | return TRUE; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
119 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
120 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
121 | /** |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
122 | * Get possible user status types. Based on mockprpl. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
123 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
124 | * @return GList of status types. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
125 | */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
126 | GList * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
127 | msim_status_types(PurpleAccount *acct) |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
128 | { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
129 | GList *types; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
130 | PurpleStatusType *status; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
131 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
132 | purple_debug_info("myspace", "returning status types\n"); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
133 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
134 | types = NULL; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
135 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
136 | /* Statuses are almost all the same. Define a macro to reduce code repetition. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
137 | #define _MSIM_ADD_NEW_STATUS(prim) status = \ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
138 | purple_status_type_new_with_attrs( \ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
139 | prim, /* PurpleStatusPrimitive */ \ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
140 | NULL, /* id - use default */ \ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
141 | NULL, /* name - use default */ \ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
142 | TRUE, /* savable */ \ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
143 | TRUE, /* user_settable */ \ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
144 | FALSE, /* not independent */ \ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
145 | \ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
146 | /* Attributes - each status can have a message. */ \ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
147 | "message", \ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
148 | _("Message"), \ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
149 | purple_value_new(PURPLE_TYPE_STRING), \ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
150 | NULL); \ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
151 | \ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
152 | \ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
153 | types = g_list_append(types, status) |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
154 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
155 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
156 | _MSIM_ADD_NEW_STATUS(PURPLE_STATUS_AVAILABLE); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
157 | _MSIM_ADD_NEW_STATUS(PURPLE_STATUS_AWAY); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
158 | _MSIM_ADD_NEW_STATUS(PURPLE_STATUS_OFFLINE); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
159 | _MSIM_ADD_NEW_STATUS(PURPLE_STATUS_INVISIBLE); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
160 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
161 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
162 | return types; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
163 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
164 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
165 | /** |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
166 | * Return the icon name for a buddy and account. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
167 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
168 | * @param acct The account to find the icon for, or NULL for protocol icon. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
169 | * @param buddy The buddy to find the icon for, or NULL for the account icon. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
170 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
171 | * @return The base icon name string. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
172 | */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
173 | const gchar * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
174 | msim_list_icon(PurpleAccount *acct, PurpleBuddy *buddy) |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
175 | { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
176 | /* Use a MySpace icon submitted by hbons at |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
177 | * http://developer.pidgin.im/wiki/MySpaceIM. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
178 | return "myspace"; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
179 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
180 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
181 | #ifdef MSIM_DEBUG_MSG |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
182 | static void |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
183 | print_hash_item(gpointer key, gpointer value, gpointer user_data) |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
184 | { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
185 | purple_debug_info("msim", "%s=%s\n", |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
186 | key ? (gchar *)key : "(NULL)", |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
187 | value ? (gchar *)value : "(NULL)"); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
188 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
189 | #endif |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
190 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
191 | /** |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
192 | * Send raw data (given as a NUL-terminated string) to the server. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
193 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
194 | * @param session |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
195 | * @param msg The raw data to send, in a NUL-terminated string. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
196 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
197 | * @return TRUE if succeeded, FALSE if not. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
198 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
199 | */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
200 | gboolean |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
201 | msim_send_raw(MsimSession *session, const gchar *msg) |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
202 | { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
203 | g_return_val_if_fail(MSIM_SESSION_VALID(session), FALSE); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
204 | g_return_val_if_fail(msg != NULL, FALSE); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
205 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
206 | purple_debug_info("msim", "msim_send_raw: writing <%s>\n", msg); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
207 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
208 | return msim_send_really_raw(session->gc, msg, strlen(msg)) == |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
209 | strlen(msg); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
210 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
211 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
212 | /** Send raw data to the server, possibly with embedded NULs. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
213 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
214 | * Used in prpl_info struct, so that plugins can have the most possible |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
215 | * control of what is sent over the connection. Inside this prpl, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
216 | * msim_send_raw() is used, since it sends NUL-terminated strings (easier). |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
217 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
218 | * @param gc PurpleConnection |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
219 | * @param buf Buffer to send |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
220 | * @param total_bytes Size of buffer to send |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
221 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
222 | * @return Bytes successfully sent, or -1 on error. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
223 | */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
224 | static int |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
225 | msim_send_really_raw(PurpleConnection *gc, const char *buf, int total_bytes) |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
226 | { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
227 | int total_bytes_sent; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
228 | MsimSession *session; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
229 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
230 | g_return_val_if_fail(gc != NULL, -1); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
231 | g_return_val_if_fail(buf != NULL, -1); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
232 | g_return_val_if_fail(total_bytes >= 0, -1); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
233 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
234 | session = (MsimSession *)gc->proto_data; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
235 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
236 | g_return_val_if_fail(MSIM_SESSION_VALID(session), -1); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
237 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
238 | /* Loop until all data is sent, or a failure occurs. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
239 | total_bytes_sent = 0; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
240 | do { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
241 | int bytes_sent; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
242 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
243 | bytes_sent = send(session->fd, buf + total_bytes_sent, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
244 | total_bytes - total_bytes_sent, 0); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
245 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
246 | if (bytes_sent < 0) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
247 | purple_debug_info("msim", "msim_send_raw(%s): send() failed: %s\n", |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
248 | buf, g_strerror(errno)); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
249 | return total_bytes_sent; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
250 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
251 | total_bytes_sent += bytes_sent; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
252 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
253 | } while(total_bytes_sent < total_bytes); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
254 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
255 | return total_bytes_sent; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
256 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
257 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
258 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
259 | /** |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
260 | * Start logging in to the MSIM servers. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
261 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
262 | * @param acct Account information to use to login. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
263 | */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
264 | void |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
265 | msim_login(PurpleAccount *acct) |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
266 | { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
267 | PurpleConnection *gc; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
268 | const gchar *host; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
269 | int port; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
270 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
271 | g_return_if_fail(acct != NULL); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
272 | g_return_if_fail(acct->username != NULL); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
273 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
274 | purple_debug_info("msim", "logging in %s\n", acct->username); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
275 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
276 | gc = purple_account_get_connection(acct); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
277 | gc->proto_data = msim_session_new(acct); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
278 | gc->flags |= PURPLE_CONNECTION_HTML | PURPLE_CONNECTION_NO_URLDESC; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
279 | |
|
19510
1917495b301e
No longer check the length of passwords - instead, pass the password to the
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19509
diff
changeset
|
280 | #ifdef MSIM_MAX_PASSWORD_LENGTH |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
281 | /* Passwords are limited in length. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
282 | if (strlen(acct->password) > MSIM_MAX_PASSWORD_LENGTH) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
283 | gchar *str; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
284 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
285 | str = g_strdup_printf( |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
286 | _("Sorry, passwords over %d characters in length (yours is " |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
287 | "%d) are not supported by MySpace."), |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
288 | MSIM_MAX_PASSWORD_LENGTH, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
289 | (int)strlen(acct->password)); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
290 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
291 | /* Notify an error message also, because this is important! */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
292 | purple_notify_error(acct, g_strdup(_("MySpaceIM Error")), str, NULL); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
293 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
294 | purple_connection_error(gc, str); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
295 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
296 | g_free(str); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
297 | } |
|
19510
1917495b301e
No longer check the length of passwords - instead, pass the password to the
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19509
diff
changeset
|
298 | #endif |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
299 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
300 | /* 1. connect to server */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
301 | purple_connection_update_progress(gc, _("Connecting"), |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
302 | 0, /* which connection step this is */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
303 | 4); /* total number of steps */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
304 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
305 | host = purple_account_get_string(acct, "server", MSIM_SERVER); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
306 | port = purple_account_get_int(acct, "port", MSIM_PORT); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
307 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
308 | /* From purple.sf.net/api: |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
309 | * """Note that this function name can be misleading--although it is called |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
310 | * "proxy connect," it is used for establishing any outgoing TCP connection, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
311 | * whether through a proxy or not.""" */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
312 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
313 | /* Calls msim_connect_cb when connected. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
314 | if (!purple_proxy_connect(gc, acct, host, port, msim_connect_cb, gc)) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
315 | /* TODO: try other ports if in auto mode, then save |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
316 | * working port and try that first next time. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
317 | purple_connection_error(gc, _("Couldn't create socket")); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
318 | return; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
319 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
320 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
321 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
322 | /** |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
323 | * Process a login challenge, sending a response. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
324 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
325 | * @param session |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
326 | * @param msg Login challenge message. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
327 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
328 | * @return TRUE if successful, FALSE if not |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
329 | */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
330 | static gboolean |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
331 | msim_login_challenge(MsimSession *session, MsimMessage *msg) |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
332 | { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
333 | PurpleAccount *account; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
334 | const gchar *response; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
335 | guint response_len; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
336 | gchar *nc; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
337 | gsize nc_len; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
338 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
339 | g_return_val_if_fail(MSIM_SESSION_VALID(session), FALSE); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
340 | g_return_val_if_fail(msg != NULL, FALSE); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
341 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
342 | g_return_val_if_fail(msim_msg_get_binary(msg, "nc", &nc, &nc_len), FALSE); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
343 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
344 | account = session->account; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
345 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
346 | g_return_val_if_fail(account != NULL, FALSE); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
347 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
348 | purple_connection_update_progress(session->gc, _("Reading challenge"), 1, 4); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
349 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
350 | purple_debug_info("msim", "nc is %d bytes, decoded\n", nc_len); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
351 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
352 | if (nc_len != MSIM_AUTH_CHALLENGE_LENGTH) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
353 | purple_debug_info("msim", "bad nc length: %x != 0x%x\n", nc_len, MSIM_AUTH_CHALLENGE_LENGTH); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
354 | purple_connection_error(session->gc, _("Unexpected challenge length from server")); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
355 | return FALSE; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
356 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
357 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
358 | purple_connection_update_progress(session->gc, _("Logging in"), 2, 4); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
359 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
360 | response_len = 0; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
361 | response = msim_compute_login_response(nc, account->username, account->password, &response_len); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
362 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
363 | g_free(nc); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
364 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
365 | return msim_send(session, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
366 | "login2", MSIM_TYPE_INTEGER, MSIM_AUTH_ALGORITHM, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
367 | /* This is actually user's email address. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
368 | "username", MSIM_TYPE_STRING, g_strdup(account->username), |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
369 | /* GString and gchar * response will be freed in msim_msg_free() in msim_send(). */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
370 | "response", MSIM_TYPE_BINARY, g_string_new_len(response, response_len), |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
371 | "clientver", MSIM_TYPE_INTEGER, MSIM_CLIENT_VERSION, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
372 | "langid", MSIM_TYPE_INTEGER, MSIM_LANGUAGE_ID_ENGLISH, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
373 | "imlang", MSIM_TYPE_STRING, g_strdup(MSIM_LANGUAGE_NAME_ENGLISH), |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
374 | "reconn", MSIM_TYPE_INTEGER, 0, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
375 | "status", MSIM_TYPE_INTEGER, 100, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
376 | "id", MSIM_TYPE_INTEGER, 1, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
377 | NULL); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
378 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
379 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
380 | /** |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
381 | * Compute the base64'd login challenge response based on username, password, nonce, and IPs. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
382 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
383 | * @param nonce The base64 encoded nonce ('nc') field from the server. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
384 | * @param email User's email address (used as login name). |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
385 | * @param password User's cleartext password. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
386 | * @param response_len Will be written with response length. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
387 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
388 | * @return Binary login challenge response, ready to send to the server. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
389 | * Must be g_free()'d when finished. NULL if error. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
390 | */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
391 | static const gchar * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
392 | msim_compute_login_response(const gchar nonce[2 * NONCE_SIZE], |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
393 | const gchar *email, const gchar *password, guint *response_len) |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
394 | { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
395 | PurpleCipherContext *key_context; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
396 | PurpleCipher *sha1; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
397 | PurpleCipherContext *rc4; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
398 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
399 | guchar hash_pw[HASH_SIZE]; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
400 | guchar key[HASH_SIZE]; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
401 | gchar *password_utf16le, *password_utf8_lc; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
402 | guchar *data; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
403 | guchar *data_out; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
404 | size_t data_len, data_out_len; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
405 | gsize conv_bytes_read, conv_bytes_written; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
406 | GError *conv_error; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
407 | #ifdef MSIM_DEBUG_LOGIN_CHALLENGE |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
408 | int i; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
409 | #endif |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
410 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
411 | g_return_val_if_fail(nonce != NULL, NULL); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
412 | g_return_val_if_fail(email != NULL, NULL); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
413 | g_return_val_if_fail(password != NULL, NULL); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
414 | g_return_val_if_fail(response_len != NULL, NULL); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
415 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
416 | /* Convert password to lowercase (required for passwords containing |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
417 | * uppercase characters). MySpace passwords are lowercase, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
418 | * see ticket #2066. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
419 | password_utf8_lc = g_utf8_strdown(password, -1); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
420 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
421 | /* Convert ASCII password to UTF16 little endian */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
422 | purple_debug_info("msim", "converting password to UTF-16LE\n"); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
423 | conv_error = NULL; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
424 | password_utf16le = g_convert(password_utf8_lc, -1, "UTF-16LE", "UTF-8", |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
425 | &conv_bytes_read, &conv_bytes_written, &conv_error); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
426 | g_free(password_utf8_lc); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
427 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
428 | g_return_val_if_fail(conv_bytes_read == strlen(password), NULL); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
429 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
430 | if (conv_error != NULL) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
431 | purple_debug_error("msim", |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
432 | "g_convert password UTF8->UTF16LE failed: %s", |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
433 | conv_error->message); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
434 | g_error_free(conv_error); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
435 | return NULL; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
436 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
437 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
438 | /* Compute password hash */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
439 | purple_cipher_digest_region("sha1", (guchar *)password_utf16le, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
440 | conv_bytes_written, sizeof(hash_pw), hash_pw, NULL); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
441 | g_free(password_utf16le); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
442 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
443 | #ifdef MSIM_DEBUG_LOGIN_CHALLENGE |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
444 | purple_debug_info("msim", "pwhash = "); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
445 | for (i = 0; i < sizeof(hash_pw); i++) |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
446 | purple_debug_info("msim", "%.2x ", hash_pw[i]); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
447 | purple_debug_info("msim", "\n"); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
448 | #endif |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
449 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
450 | /* key = sha1(sha1(pw) + nonce2) */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
451 | sha1 = purple_ciphers_find_cipher("sha1"); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
452 | key_context = purple_cipher_context_new(sha1, NULL); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
453 | purple_cipher_context_append(key_context, hash_pw, HASH_SIZE); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
454 | purple_cipher_context_append(key_context, (guchar *)(nonce + NONCE_SIZE), NONCE_SIZE); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
455 | purple_cipher_context_digest(key_context, sizeof(key), key, NULL); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
456 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
457 | #ifdef MSIM_DEBUG_LOGIN_CHALLENGE |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
458 | purple_debug_info("msim", "key = "); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
459 | for (i = 0; i < sizeof(key); i++) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
460 | purple_debug_info("msim", "%.2x ", key[i]); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
461 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
462 | purple_debug_info("msim", "\n"); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
463 | #endif |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
464 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
465 | rc4 = purple_cipher_context_new_by_name("rc4", NULL); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
466 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
467 | /* Note: 'key' variable is 0x14 bytes (from SHA-1 hash), |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
468 | * but only first 0x10 used for the RC4 key. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
469 | purple_cipher_context_set_option(rc4, "key_len", (gpointer)0x10); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
470 | purple_cipher_context_set_key(rc4, key); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
471 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
472 | /* TODO: obtain IPs of network interfaces */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
473 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
474 | /* rc4 encrypt: |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
475 | * nonce1+email+IP list */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
476 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
477 | data_len = NONCE_SIZE + strlen(email) + MSIM_LOGIN_IP_LIST_LEN; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
478 | data = g_new0(guchar, data_len); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
479 | memcpy(data, nonce, NONCE_SIZE); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
480 | memcpy(data + NONCE_SIZE, email, strlen(email)); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
481 | memcpy(data + NONCE_SIZE + strlen(email), MSIM_LOGIN_IP_LIST, MSIM_LOGIN_IP_LIST_LEN); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
482 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
483 | data_out = g_new0(guchar, data_len); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
484 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
485 | purple_cipher_context_encrypt(rc4, (const guchar *)data, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
486 | data_len, data_out, &data_out_len); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
487 | purple_cipher_context_destroy(rc4); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
488 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
489 | g_assert(data_out_len == data_len); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
490 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
491 | #ifdef MSIM_DEBUG_LOGIN_CHALLENGE |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
492 | purple_debug_info("msim", "response=<%s>\n", data_out); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
493 | #endif |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
494 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
495 | *response_len = data_out_len; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
496 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
497 | return (const gchar *)data_out; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
498 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
499 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
500 | /** |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
501 | * Schedule an IM to be sent once the user ID is looked up. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
502 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
503 | * @param gc Connection. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
504 | * @param who A user id, email, or username to send the message to. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
505 | * @param message Instant message text to send. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
506 | * @param flags Flags. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
507 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
508 | * @return 1 if successful or postponed, -1 if failed |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
509 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
510 | * Allows sending to a user by username, email address, or userid. If |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
511 | * a username or email address is given, the userid must be looked up. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
512 | * This function does that by calling msim_postprocess_outgoing(). |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
513 | */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
514 | int |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
515 | msim_send_im(PurpleConnection *gc, const gchar *who, const gchar *message, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
516 | PurpleMessageFlags flags) |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
517 | { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
518 | MsimSession *session; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
519 | gchar *message_msim; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
520 | int rc; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
521 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
522 | g_return_val_if_fail(gc != NULL, -1); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
523 | g_return_val_if_fail(who != NULL, -1); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
524 | g_return_val_if_fail(message != NULL, -1); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
525 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
526 | /* 'flags' has many options, not used here. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
527 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
528 | session = (MsimSession *)gc->proto_data; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
529 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
530 | g_return_val_if_fail(MSIM_SESSION_VALID(session), -1); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
531 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
532 | message_msim = html_to_msim_markup(session, message); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
533 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
534 | if (msim_send_bm(session, who, message_msim, MSIM_BM_INSTANT)) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
535 | /* Return 1 to have Purple show this IM as being sent, 0 to not. I always |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
536 | * return 1 even if the message could not be sent, since I don't know if |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
537 | * it has failed yet--because the IM is only sent after the userid is |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
538 | * retrieved from the server (which happens after this function returns). |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
539 | */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
540 | /* TODO: maybe if message is delayed, don't echo to conv window, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
541 | * but do echo it to conv window manually once it is actually |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
542 | * sent? Would be complicated. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
543 | rc = 1; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
544 | } else { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
545 | rc = -1; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
546 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
547 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
548 | g_free(message_msim); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
549 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
550 | /* |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
551 | * In MySpace, you login with your email address, but don't talk to other |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
552 | * users using their email address. So there is currently an asymmetry in the |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
553 | * IM windows when using this plugin: |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
554 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
555 | * you@example.com: hello |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
556 | * some_other_user: what's going on? |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
557 | * you@example.com: just coding a prpl |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
558 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
559 | * TODO: Make the sent IM's appear as from the user's username, instead of |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
560 | * their email address. Purple uses the login (in MSIM, the email)--change this. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
561 | */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
562 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
563 | return rc; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
564 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
565 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
566 | /** Send a buddy message of a given type. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
567 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
568 | * @param session |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
569 | * @param who Username to send message to. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
570 | * @param text Message text to send. Not freed; will be copied. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
571 | * @param type A MSIM_BM_* constant. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
572 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
573 | * @return TRUE if success, FALSE if fail. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
574 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
575 | * Buddy messages ('bm') include instant messages, action messages, status messages, etc. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
576 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
577 | */ |
|
19616
017838ce7393
In msimprpl, move zap-related code to a separate module.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19615
diff
changeset
|
578 | gboolean |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
579 | msim_send_bm(MsimSession *session, const gchar *who, const gchar *text, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
580 | int type) |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
581 | { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
582 | gboolean rc; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
583 | MsimMessage *msg; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
584 | const gchar *from_username; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
585 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
586 | g_return_val_if_fail(MSIM_SESSION_VALID(session), FALSE); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
587 | g_return_val_if_fail(who != NULL, FALSE); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
588 | g_return_val_if_fail(text != NULL, FALSE); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
589 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
590 | from_username = session->account->username; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
591 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
592 | g_return_val_if_fail(from_username != NULL, FALSE); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
593 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
594 | purple_debug_info("msim", "sending %d message from %s to %s: %s\n", |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
595 | type, from_username, who, text); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
596 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
597 | msg = msim_msg_new( |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
598 | "bm", MSIM_TYPE_INTEGER, GUINT_TO_POINTER(type), |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
599 | "sesskey", MSIM_TYPE_INTEGER, GUINT_TO_POINTER(session->sesskey), |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
600 | /* 't' will be inserted here */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
601 | "cv", MSIM_TYPE_INTEGER, GUINT_TO_POINTER(MSIM_CLIENT_VERSION), |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
602 | "msg", MSIM_TYPE_STRING, g_strdup(text), |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
603 | NULL); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
604 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
605 | rc = msim_postprocess_outgoing(session, msg, who, "t", "cv"); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
606 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
607 | msim_msg_free(msg); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
608 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
609 | return rc; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
610 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
611 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
612 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
613 | /** Record the client version in the buddy list, from an incoming message. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
614 | static gboolean |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
615 | msim_incoming_bm_record_cv(MsimSession *session, MsimMessage *msg) |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
616 | { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
617 | gchar *username, *cv; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
618 | gboolean ret; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
619 | MsimUser *user; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
620 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
621 | username = msim_msg_get_string(msg, "_username"); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
622 | cv = msim_msg_get_string(msg, "cv"); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
623 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
624 | g_return_val_if_fail(username != NULL, FALSE); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
625 | if (!cv) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
626 | /* No client version to record, don't worry about it. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
627 | return FALSE; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
628 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
629 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
630 | user = msim_find_user(session, username); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
631 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
632 | if (user) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
633 | user->client_cv = atol(cv); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
634 | ret = TRUE; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
635 | } else { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
636 | ret = FALSE; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
637 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
638 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
639 | g_free(username); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
640 | g_free(cv); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
641 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
642 | return ret; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
643 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
644 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
645 | /** Handle an incoming buddy message. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
646 | static gboolean |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
647 | msim_incoming_bm(MsimSession *session, MsimMessage *msg) |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
648 | { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
649 | guint bm; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
650 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
651 | bm = msim_msg_get_integer(msg, "bm"); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
652 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
653 | msim_incoming_bm_record_cv(session, msg); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
654 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
655 | switch (bm) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
656 | case MSIM_BM_STATUS: |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
657 | return msim_incoming_status(session, msg); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
658 | case MSIM_BM_INSTANT: |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
659 | return msim_incoming_im(session, msg); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
660 | case MSIM_BM_ACTION: |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
661 | return msim_incoming_action(session, msg); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
662 | case MSIM_BM_MEDIA: |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
663 | return msim_incoming_media(session, msg); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
664 | case MSIM_BM_UNOFFICIAL_CLIENT: |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
665 | return msim_incoming_unofficial_client(session, msg); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
666 | default: |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
667 | /* Not really an IM, but show it for informational |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
668 | * purposes during development. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
669 | return msim_incoming_im(session, msg); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
670 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
671 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
672 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
673 | /** |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
674 | * Handle an incoming instant message. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
675 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
676 | * @param session The session |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
677 | * @param msg Message from the server, containing 'f' (userid from) and 'msg'. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
678 | * Should also contain username in _username from preprocessing. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
679 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
680 | * @return TRUE if successful. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
681 | */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
682 | static gboolean |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
683 | msim_incoming_im(MsimSession *session, MsimMessage *msg) |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
684 | { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
685 | gchar *username, *msg_msim_markup, *msg_purple_markup; |
|
19730
cb50f6696994
Use the sent timestamp in incoming instant messages instead of the current
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19644
diff
changeset
|
686 | time_t time_received; |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
687 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
688 | g_return_val_if_fail(MSIM_SESSION_VALID(session), FALSE); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
689 | g_return_val_if_fail(msg != NULL, FALSE); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
690 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
691 | username = msim_msg_get_string(msg, "_username"); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
692 | g_return_val_if_fail(username != NULL, FALSE); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
693 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
694 | msg_msim_markup = msim_msg_get_string(msg, "msg"); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
695 | g_return_val_if_fail(msg_msim_markup != NULL, FALSE); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
696 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
697 | msg_purple_markup = msim_markup_to_html(session, msg_msim_markup); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
698 | g_free(msg_msim_markup); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
699 | |
|
19730
cb50f6696994
Use the sent timestamp in incoming instant messages instead of the current
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19644
diff
changeset
|
700 | time_received = msim_msg_get_integer(msg, "date"); |
|
cb50f6696994
Use the sent timestamp in incoming instant messages instead of the current
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19644
diff
changeset
|
701 | if (!time_received) { |
|
cb50f6696994
Use the sent timestamp in incoming instant messages instead of the current
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19644
diff
changeset
|
702 | time_received = time(NULL); |
|
cb50f6696994
Use the sent timestamp in incoming instant messages instead of the current
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19644
diff
changeset
|
703 | } |
|
cb50f6696994
Use the sent timestamp in incoming instant messages instead of the current
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19644
diff
changeset
|
704 | |
|
cb50f6696994
Use the sent timestamp in incoming instant messages instead of the current
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19644
diff
changeset
|
705 | serv_got_im(session->gc, username, msg_purple_markup, PURPLE_MESSAGE_RECV, time_received); |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
706 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
707 | g_free(username); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
708 | g_free(msg_purple_markup); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
709 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
710 | return TRUE; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
711 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
712 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
713 | /** |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
714 | * Process unrecognized information. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
715 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
716 | * @param session |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
717 | * @param msg An MsimMessage that was unrecognized, or NULL. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
718 | * @param note Information on what was unrecognized, or NULL. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
719 | */ |
|
19619
e9ac2df3fd1b
In msimprpl, move user-related code to a new user module, and move other
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19618
diff
changeset
|
720 | void |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
721 | msim_unrecognized(MsimSession *session, MsimMessage *msg, gchar *note) |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
722 | { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
723 | /* TODO: Some more context, outwardly equivalent to a backtrace, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
724 | * for helping figure out what this msg is for. What was going on? |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
725 | * But not too much information so that a user |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
726 | * posting this dump reveals confidential information. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
727 | */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
728 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
729 | /* TODO: dump unknown msgs to file, so user can send them to me |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
730 | * if they wish, to help add support for new messages (inspired |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
731 | * by Alexandr Shutko, who maintains OSCAR protocol documentation). */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
732 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
733 | purple_debug_info("msim", "Unrecognized data on account for %s\n", |
|
19530
6ced4ef3e757
MySpace added a new field, LastImageUpdated. Save it in MsimUser.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19529
diff
changeset
|
734 | (session && session->account && session->account->username) ? |
|
6ced4ef3e757
MySpace added a new field, LastImageUpdated. Save it in MsimUser.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19529
diff
changeset
|
735 | session->account->username : "(NULL)"); |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
736 | if (note) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
737 | purple_debug_info("msim", "(Note: %s)\n", note); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
738 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
739 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
740 | if (msg) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
741 | msim_msg_dump("Unrecognized message dump: %s\n", msg); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
742 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
743 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
744 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
745 | /** |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
746 | * Handle an incoming action message. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
747 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
748 | * @param session |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
749 | * @param msg |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
750 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
751 | * @return TRUE if successful. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
752 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
753 | */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
754 | static gboolean |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
755 | msim_incoming_action(MsimSession *session, MsimMessage *msg) |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
756 | { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
757 | gchar *msg_text, *username; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
758 | gboolean rc; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
759 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
760 | g_return_val_if_fail(MSIM_SESSION_VALID(session), FALSE); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
761 | g_return_val_if_fail(msg != NULL, FALSE); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
762 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
763 | msg_text = msim_msg_get_string(msg, "msg"); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
764 | g_return_val_if_fail(msg_text != NULL, FALSE); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
765 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
766 | username = msim_msg_get_string(msg, "_username"); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
767 | g_return_val_if_fail(username != NULL, FALSE); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
768 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
769 | purple_debug_info("msim", "msim_incoming_action: action <%s> from <%d>\n", |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
770 | msg_text, username); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
771 | |
|
19606
afc90bd82e6d
In msimprpl, replace !strcmp() with g_str_equal() everywhere.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19605
diff
changeset
|
772 | if (g_str_equal(msg_text, "%typing%")) { |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
773 | /* TODO: find out if msim repeatedly sends typing messages, so we can |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
774 | * give it a timeout. Right now, there does seem to be an inordinately |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
775 | * amount of time between typing stopped-typing notifications. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
776 | serv_got_typing(session->gc, username, 0, PURPLE_TYPING); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
777 | rc = TRUE; |
|
19606
afc90bd82e6d
In msimprpl, replace !strcmp() with g_str_equal() everywhere.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19605
diff
changeset
|
778 | } else if (g_str_equal(msg_text, "%stoptyping%")) { |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
779 | serv_got_typing_stopped(session->gc, username); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
780 | rc = TRUE; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
781 | } else if (strstr(msg_text, "!!!ZAP_SEND!!!=RTE_BTN_ZAPS_")) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
782 | rc = msim_incoming_zap(session, msg); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
783 | } else { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
784 | msim_unrecognized(session, msg, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
785 | "got to msim_incoming_action but unrecognized value for 'msg'"); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
786 | rc = FALSE; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
787 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
788 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
789 | g_free(msg_text); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
790 | g_free(username); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
791 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
792 | return rc; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
793 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
794 | |
|
19528
158870ab9228
g_memdup() the icon data before setting it as the buddy icon.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19527
diff
changeset
|
795 | /* Process an incoming media (message background?) message. */ |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
796 | static gboolean |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
797 | msim_incoming_media(MsimSession *session, MsimMessage *msg) |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
798 | { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
799 | gchar *username, *text; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
800 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
801 | username = msim_msg_get_string(msg, "_username"); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
802 | text = msim_msg_get_string(msg, "msg"); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
803 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
804 | g_return_val_if_fail(username != NULL, FALSE); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
805 | g_return_val_if_fail(text != NULL, FALSE); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
806 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
807 | purple_debug_info("msim", "msim_incoming_media: from %s, got msg=%s\n", username, text); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
808 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
809 | /* Media messages are sent when the user opens a window to someone. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
810 | * Tell libpurple they started typing and stopped typing, to inform the Psychic |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
811 | * Mode plugin so it too can open a window to the user. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
812 | serv_got_typing(session->gc, username, 0, PURPLE_TYPING); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
813 | serv_got_typing_stopped(session->gc, username); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
814 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
815 | g_free(username); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
816 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
817 | return TRUE; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
818 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
819 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
820 | /* Process an incoming "unofficial client" message. The plugin for |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
821 | * Miranda IM sends this message with the plugin information. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
822 | static gboolean |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
823 | msim_incoming_unofficial_client(MsimSession *session, MsimMessage *msg) |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
824 | { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
825 | MsimUser *user; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
826 | gchar *username, *client_info; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
827 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
828 | username = msim_msg_get_string(msg, "_username"); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
829 | client_info = msim_msg_get_string(msg, "msg"); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
830 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
831 | g_return_val_if_fail(username != NULL, FALSE); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
832 | g_return_val_if_fail(client_info != NULL, FALSE); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
833 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
834 | purple_debug_info("msim", "msim_incoming_unofficial_client: %s is using client %s\n", |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
835 | username, client_info); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
836 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
837 | user = msim_find_user(session, username); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
838 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
839 | g_return_val_if_fail(user != NULL, FALSE); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
840 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
841 | if (user->client_info) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
842 | g_free(user->client_info); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
843 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
844 | user->client_info = client_info; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
845 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
846 | g_free(username); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
847 | /* Do not free client_info - the MsimUser now owns it. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
848 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
849 | return TRUE; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
850 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
851 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
852 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
853 | #ifdef MSIM_SEND_CLIENT_VERSION |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
854 | /** Send our client version to another unofficial client that understands it. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
855 | static gboolean |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
856 | msim_send_unofficial_client(MsimSession *session, gchar *username) |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
857 | { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
858 | gchar *our_info; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
859 | gboolean ret; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
860 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
861 | our_info = g_strdup_printf("Libpurple %d.%d.%d - msimprpl %s", |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
862 | PURPLE_MAJOR_VERSION, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
863 | PURPLE_MINOR_VERSION, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
864 | PURPLE_MICRO_VERSION, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
865 | MSIM_PRPL_VERSION_STRING); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
866 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
867 | ret = msim_send_bm(session, username, our_info, MSIM_BM_UNOFFICIAL_CLIENT); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
868 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
869 | return ret; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
870 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
871 | #endif |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
872 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
873 | /** |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
874 | * Handle when our user starts or stops typing to another user. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
875 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
876 | * @param gc |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
877 | * @param name The buddy name to which our user is typing to |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
878 | * @param state PURPLE_TYPING, PURPLE_TYPED, PURPLE_NOT_TYPING |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
879 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
880 | * @return 0 |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
881 | */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
882 | unsigned int |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
883 | msim_send_typing(PurpleConnection *gc, const gchar *name, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
884 | PurpleTypingState state) |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
885 | { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
886 | const gchar *typing_str; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
887 | MsimSession *session; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
888 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
889 | g_return_val_if_fail(gc != NULL, 0); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
890 | g_return_val_if_fail(name != NULL, 0); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
891 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
892 | session = (MsimSession *)gc->proto_data; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
893 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
894 | g_return_val_if_fail(MSIM_SESSION_VALID(session), 0); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
895 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
896 | switch (state) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
897 | case PURPLE_TYPING: |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
898 | typing_str = "%typing%"; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
899 | break; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
900 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
901 | case PURPLE_TYPED: |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
902 | case PURPLE_NOT_TYPING: |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
903 | default: |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
904 | typing_str = "%stoptyping%"; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
905 | break; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
906 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
907 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
908 | purple_debug_info("msim", "msim_send_typing(%s): %d (%s)\n", name, state, typing_str); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
909 | msim_send_bm(session, name, typing_str, MSIM_BM_ACTION); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
910 | return 0; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
911 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
912 | |
|
19619
e9ac2df3fd1b
In msimprpl, move user-related code to a new user module, and move other
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19618
diff
changeset
|
913 | |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
914 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
915 | /** Callback for msim_get_info(), for when user info is received. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
916 | static void |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
917 | msim_get_info_cb(MsimSession *session, MsimMessage *user_info_msg, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
918 | gpointer data) |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
919 | { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
920 | MsimMessage *msg; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
921 | gchar *username; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
922 | PurpleNotifyUserInfo *user_info; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
923 | MsimUser *user; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
924 | gboolean temporary_user; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
925 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
926 | g_return_if_fail(MSIM_SESSION_VALID(session)); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
927 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
928 | /* Get user{name,id} from msim_get_info, passed as an MsimMessage for |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
929 | orthogonality. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
930 | msg = (MsimMessage *)data; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
931 | g_return_if_fail(msg != NULL); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
932 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
933 | username = msim_msg_get_string(msg, "user"); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
934 | if (!username) { |
|
19832
84b69b21672b
Patch from QuLogic. Fixes #2903 ('Missing newlines in debug messages.')
Sadrul Habib Chowdhury <sadrul@pidgin.im>
parents:
19816
diff
changeset
|
935 | purple_debug_info("msim", "msim_get_info_cb: no 'user' in msg\n"); |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
936 | return; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
937 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
938 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
939 | msim_msg_free(msg); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
940 | purple_debug_info("msim", "msim_get_info_cb: got for user: %s\n", username); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
941 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
942 | user = msim_find_user(session, username); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
943 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
944 | if (!user) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
945 | /* User isn't on blist, create a temporary user to store info. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
946 | temporary_user = TRUE; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
947 | user = g_new0(MsimUser, 1); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
948 | } else { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
949 | temporary_user = FALSE; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
950 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
951 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
952 | /* Update user structure with new information */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
953 | msim_store_user_info(session, user_info_msg, user); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
954 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
955 | user_info = purple_notify_user_info_new(); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
956 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
957 | /* Append data from MsimUser to PurpleNotifyUserInfo for display, full */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
958 | msim_append_user_info(session, user_info, user, TRUE); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
959 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
960 | purple_notify_userinfo(session->gc, username, user_info, NULL, NULL); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
961 | purple_debug_info("msim", "msim_get_info_cb: username=%s\n", username); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
962 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
963 | purple_notify_user_info_destroy(user_info); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
964 | /* TODO: do not free username, since it will be used by user_info? */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
965 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
966 | if (temporary_user) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
967 | g_free(user->client_info); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
968 | g_free(user->gender); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
969 | g_free(user->location); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
970 | g_free(user->headline); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
971 | g_free(user->display_name); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
972 | g_free(user->username); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
973 | g_free(user->band_name); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
974 | g_free(user->song_name); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
975 | g_free(user->image_url); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
976 | g_free(user); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
977 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
978 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
979 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
980 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
981 | /** Retrieve a user's profile. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
982 | * @param username Username, user ID, or email address to lookup. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
983 | */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
984 | void |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
985 | msim_get_info(PurpleConnection *gc, const gchar *username) |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
986 | { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
987 | MsimSession *session; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
988 | MsimUser *user; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
989 | guint uid; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
990 | gchar *user_to_lookup; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
991 | MsimMessage *user_msg; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
992 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
993 | g_return_if_fail(gc != NULL); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
994 | g_return_if_fail(username != NULL); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
995 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
996 | session = (MsimSession *)gc->proto_data; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
997 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
998 | g_return_if_fail(MSIM_SESSION_VALID(session)); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
999 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1000 | /* Obtain uid of buddy. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1001 | user = msim_find_user(session, username); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1002 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1003 | /* If is on buddy list, lookup by uid since it is faster. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1004 | if (user && (uid = purple_blist_node_get_int(&user->buddy->node, "UserID"))) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1005 | user_to_lookup = g_strdup_printf("%d", uid); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1006 | } else { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1007 | /* Looking up buddy not on blist. Lookup by whatever user entered. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1008 | user_to_lookup = g_strdup(username); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1009 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1010 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1011 | /* Pass the username to msim_get_info_cb(), because since we lookup |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1012 | * by userid, the userinfo message will only contain the uid (not |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1013 | * the username) but it would be useful to display the username too. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1014 | */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1015 | user_msg = msim_msg_new( |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1016 | "user", MSIM_TYPE_STRING, g_strdup(username), |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1017 | NULL); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1018 | purple_debug_info("msim", "msim_get_info, setting up lookup, user=%s\n", username); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1019 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1020 | msim_lookup_user(session, user_to_lookup, msim_get_info_cb, user_msg); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1021 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1022 | g_free(user_to_lookup); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1023 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1024 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1025 | /** Set your status - callback for when user manually sets it. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1026 | void |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1027 | msim_set_status(PurpleAccount *account, PurpleStatus *status) |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1028 | { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1029 | PurpleStatusType *type; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1030 | MsimSession *session; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1031 | guint status_code; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1032 | const gchar *statstring; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1033 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1034 | session = (MsimSession *)account->gc->proto_data; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1035 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1036 | g_return_if_fail(MSIM_SESSION_VALID(session)); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1037 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1038 | type = purple_status_get_type(status); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1039 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1040 | switch (purple_status_type_get_primitive(type)) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1041 | case PURPLE_STATUS_AVAILABLE: |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1042 | purple_debug_info("msim", "msim_set_status: available (%d->%d)\n", PURPLE_STATUS_AVAILABLE, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1043 | MSIM_STATUS_CODE_ONLINE); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1044 | status_code = MSIM_STATUS_CODE_ONLINE; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1045 | break; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1046 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1047 | case PURPLE_STATUS_INVISIBLE: |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1048 | purple_debug_info("msim", "msim_set_status: invisible (%d->%d)\n", PURPLE_STATUS_INVISIBLE, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1049 | MSIM_STATUS_CODE_OFFLINE_OR_HIDDEN); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1050 | status_code = MSIM_STATUS_CODE_OFFLINE_OR_HIDDEN; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1051 | break; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1052 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1053 | case PURPLE_STATUS_AWAY: |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1054 | purple_debug_info("msim", "msim_set_status: away (%d->%d)\n", PURPLE_STATUS_AWAY, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1055 | MSIM_STATUS_CODE_AWAY); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1056 | status_code = MSIM_STATUS_CODE_AWAY; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1057 | break; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1058 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1059 | default: |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1060 | purple_debug_info("msim", "msim_set_status: unknown " |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1061 | "status interpreting as online"); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1062 | status_code = MSIM_STATUS_CODE_ONLINE; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1063 | break; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1064 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1065 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1066 | statstring = purple_status_get_attr_string(status, "message"); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1067 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1068 | if (!statstring) { |
|
19731
844a19c41487
Treat status messages as the plaintext that they are.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19730
diff
changeset
|
1069 | statstring = ""; |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1070 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1071 | |
|
19731
844a19c41487
Treat status messages as the plaintext that they are.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19730
diff
changeset
|
1072 | /* Status strings are plain text. */ |
|
844a19c41487
Treat status messages as the plaintext that they are.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19730
diff
changeset
|
1073 | statstring = purple_markup_strip_html(statstring); |
|
844a19c41487
Treat status messages as the plaintext that they are.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19730
diff
changeset
|
1074 | |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1075 | msim_set_status_code(session, status_code, g_strdup(statstring)); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1076 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1077 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1078 | /** Go idle. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1079 | void |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1080 | msim_set_idle(PurpleConnection *gc, int time) |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1081 | { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1082 | MsimSession *session; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1083 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1084 | g_return_if_fail(gc != NULL); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1085 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1086 | session = (MsimSession *)gc->proto_data; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1087 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1088 | g_return_if_fail(MSIM_SESSION_VALID(session)); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1089 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1090 | if (time == 0) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1091 | /* Going back from idle. In msim, idle is mutually exclusive |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1092 | * from the other states (you can only be away or idle, but not |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1093 | * both, for example), so by going non-idle I go online. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1094 | */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1095 | /* TODO: find out how to keep old status string? */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1096 | msim_set_status_code(session, MSIM_STATUS_CODE_ONLINE, g_strdup("")); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1097 | } else { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1098 | /* msim doesn't support idle time, so just go idle */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1099 | msim_set_status_code(session, MSIM_STATUS_CODE_IDLE, g_strdup("")); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1100 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1101 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1102 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1103 | /** Set status using an MSIM_STATUS_CODE_* value. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1104 | * @param status_code An MSIM_STATUS_CODE_* value. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1105 | * @param statstring Status string, must be a dynamic string (will be freed by msim_send). |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1106 | */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1107 | static void |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1108 | msim_set_status_code(MsimSession *session, guint status_code, gchar *statstring) |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1109 | { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1110 | g_return_if_fail(MSIM_SESSION_VALID(session)); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1111 | g_return_if_fail(statstring != NULL); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1112 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1113 | purple_debug_info("msim", "msim_set_status_code: going to set status to code=%d,str=%s\n", |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1114 | status_code, statstring); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1115 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1116 | if (!msim_send(session, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1117 | "status", MSIM_TYPE_INTEGER, status_code, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1118 | "sesskey", MSIM_TYPE_INTEGER, session->sesskey, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1119 | "statstring", MSIM_TYPE_STRING, statstring, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1120 | "locstring", MSIM_TYPE_STRING, g_strdup(""), |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1121 | NULL)) |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1122 | { |
|
19832
84b69b21672b
Patch from QuLogic. Fixes #2903 ('Missing newlines in debug messages.')
Sadrul Habib Chowdhury <sadrul@pidgin.im>
parents:
19816
diff
changeset
|
1123 | purple_debug_info("msim", "msim_set_status: failed to set status\n"); |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1124 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1125 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1126 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1127 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1128 | /** After a uid is resolved to username, tag it with the username and submit for processing. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1129 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1130 | * @param session |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1131 | * @param userinfo Response messsage to resolving request. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1132 | * @param data MsimMessage *, the message to attach information to. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1133 | */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1134 | static void |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1135 | msim_incoming_resolved(MsimSession *session, MsimMessage *userinfo, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1136 | gpointer data) |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1137 | { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1138 | gchar *username; |
|
19514
9456ceb35a25
Replace msim_parse_body(), which returns a GHashTable * and takes a gchar *,
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19512
diff
changeset
|
1139 | MsimMessage *msg, *body; |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1140 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1141 | g_return_if_fail(MSIM_SESSION_VALID(session)); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1142 | g_return_if_fail(userinfo != NULL); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1143 | |
|
19514
9456ceb35a25
Replace msim_parse_body(), which returns a GHashTable * and takes a gchar *,
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19512
diff
changeset
|
1144 | body = msim_msg_get_dictionary(userinfo, "body"); |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1145 | g_return_if_fail(body != NULL); |
|
19514
9456ceb35a25
Replace msim_parse_body(), which returns a GHashTable * and takes a gchar *,
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19512
diff
changeset
|
1146 | |
|
9456ceb35a25
Replace msim_parse_body(), which returns a GHashTable * and takes a gchar *,
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19512
diff
changeset
|
1147 | username = msim_msg_get_string(body, "UserName"); |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1148 | g_return_if_fail(username != NULL); |
|
19514
9456ceb35a25
Replace msim_parse_body(), which returns a GHashTable * and takes a gchar *,
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19512
diff
changeset
|
1149 | /* Note: username will be owned by 'msg' below. */ |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1150 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1151 | msg = (MsimMessage *)data; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1152 | g_return_if_fail(msg != NULL); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1153 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1154 | /* TODO: more elegant solution than below. attach whole message? */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1155 | /* Special elements name beginning with '_', we'll use internally within the |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1156 | * program (did not come directly from the wire). */ |
|
19514
9456ceb35a25
Replace msim_parse_body(), which returns a GHashTable * and takes a gchar *,
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19512
diff
changeset
|
1157 | msg = msim_msg_append(msg, "_username", MSIM_TYPE_STRING, username); |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1158 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1159 | /* TODO: attach more useful information, like ImageURL */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1160 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1161 | msim_process(session, msg); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1162 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1163 | /* TODO: Free copy cloned from msim_preprocess_incoming(). */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1164 | //XXX msim_msg_free(msg); |
|
19514
9456ceb35a25
Replace msim_parse_body(), which returns a GHashTable * and takes a gchar *,
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19512
diff
changeset
|
1165 | msim_msg_free(body); |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1166 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1167 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1168 | /* Lookup a username by userid, from buddy list. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1169 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1170 | * @param wanted_uid |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1171 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1172 | * @return Username of wanted_uid, if on blist, or NULL. Static string. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1173 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1174 | */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1175 | static const gchar * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1176 | msim_uid2username_from_blist(MsimSession *session, guint wanted_uid) |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1177 | { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1178 | GSList *buddies, *cur; |
|
19518
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
1179 | gchar *ret; |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1180 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1181 | buddies = purple_find_buddies(session->account, NULL); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1182 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1183 | if (!buddies) |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1184 | { |
|
19832
84b69b21672b
Patch from QuLogic. Fixes #2903 ('Missing newlines in debug messages.')
Sadrul Habib Chowdhury <sadrul@pidgin.im>
parents:
19816
diff
changeset
|
1185 | purple_debug_info("msim", "msim_uid2username_from_blist: no buddies?\n"); |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1186 | return NULL; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1187 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1188 | |
|
19518
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
1189 | ret = NULL; |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1190 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1191 | for (cur = buddies; cur != NULL; cur = g_slist_next(cur)) |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1192 | { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1193 | PurpleBuddy *buddy; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1194 | guint uid; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1195 | const gchar *name; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1196 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1197 | /* See finch/gnthistory.c */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1198 | buddy = cur->data; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1199 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1200 | uid = purple_blist_node_get_int(&buddy->node, "UserID"); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1201 | name = purple_buddy_get_name(buddy); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1202 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1203 | if (uid == wanted_uid) |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1204 | { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1205 | ret = g_strdup(name); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1206 | break; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1207 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1208 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1209 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1210 | g_slist_free(buddies); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1211 | return ret; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1212 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1213 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1214 | /** Preprocess incoming messages, resolving as needed, calling msim_process() when ready to process. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1215 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1216 | * @param session |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1217 | * @param msg MsimMessage *, freed by caller. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1218 | */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1219 | static gboolean |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1220 | msim_preprocess_incoming(MsimSession *session, MsimMessage *msg) |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1221 | { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1222 | g_return_val_if_fail(MSIM_SESSION_VALID(session), FALSE); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1223 | g_return_val_if_fail(msg != NULL, FALSE); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1224 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1225 | if (msim_msg_get(msg, "bm") && msim_msg_get(msg, "f")) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1226 | guint uid; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1227 | const gchar *username; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1228 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1229 | /* 'f' = userid message is from, in buddy messages */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1230 | uid = msim_msg_get_integer(msg, "f"); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1231 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1232 | username = msim_uid2username_from_blist(session, uid); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1233 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1234 | if (username) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1235 | /* Know username already, use it. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1236 | purple_debug_info("msim", "msim_preprocess_incoming: tagging with _username=%s\n", |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1237 | username); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1238 | msg = msim_msg_append(msg, "_username", MSIM_TYPE_STRING, g_strdup(username)); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1239 | return msim_process(session, msg); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1240 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1241 | } else { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1242 | gchar *from; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1243 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1244 | /* Send lookup request. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1245 | /* XXX: where is msim_msg_get_string() freed? make _strdup and _nonstrdup. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1246 | purple_debug_info("msim", "msim_incoming: sending lookup, setting up callback\n"); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1247 | from = msim_msg_get_string(msg, "f"); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1248 | msim_lookup_user(session, from, msim_incoming_resolved, msim_msg_clone(msg)); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1249 | g_free(from); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1250 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1251 | /* indeterminate */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1252 | return TRUE; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1253 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1254 | } else { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1255 | /* Nothing to resolve - send directly to processing. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1256 | return msim_process(session, msg); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1257 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1258 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1259 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1260 | #ifdef MSIM_USE_KEEPALIVE |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1261 | /** Check if the connection is still alive, based on last communication. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1262 | static gboolean |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1263 | msim_check_alive(gpointer data) |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1264 | { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1265 | MsimSession *session; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1266 | time_t delta; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1267 | gchar *errmsg; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1268 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1269 | session = (MsimSession *)data; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1270 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1271 | g_return_val_if_fail(MSIM_SESSION_VALID(session), FALSE); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1272 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1273 | delta = time(NULL) - session->last_comm; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1274 | //purple_debug_info("msim", "msim_check_alive: delta=%d\n", delta); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1275 | if (delta >= MSIM_KEEPALIVE_INTERVAL) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1276 | errmsg = g_strdup_printf(_("Connection to server lost (no data received within %d seconds)"), (int)delta); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1277 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1278 | purple_debug_info("msim", "msim_check_alive: %s > interval of %d, presumed dead\n", |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1279 | errmsg, MSIM_KEEPALIVE_INTERVAL); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1280 | purple_connection_error(session->gc, errmsg); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1281 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1282 | purple_notify_error(session->gc, NULL, errmsg, NULL); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1283 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1284 | g_free(errmsg); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1285 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1286 | return FALSE; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1287 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1288 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1289 | return TRUE; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1290 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1291 | #endif |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1292 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1293 | /** Handle mail reply checks. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1294 | static void |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1295 | msim_check_inbox_cb(MsimSession *session, MsimMessage *reply, gpointer data) |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1296 | { |
|
19514
9456ceb35a25
Replace msim_parse_body(), which returns a GHashTable * and takes a gchar *,
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19512
diff
changeset
|
1297 | MsimMessage *body; |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1298 | GString *notification; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1299 | guint old_inbox_status; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1300 | guint i, n; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1301 | const gchar *froms[5], *tos[5], *urls[5], *subjects[5]; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1302 | |
|
19608
7eb028d95972
In msimprpl's mail notifications, change four parallel arrays into
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19607
diff
changeset
|
1303 | /* Information for each new inbox message type. */ |
|
7eb028d95972
In msimprpl's mail notifications, change four parallel arrays into
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19607
diff
changeset
|
1304 | static struct |
|
7eb028d95972
In msimprpl's mail notifications, change four parallel arrays into
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19607
diff
changeset
|
1305 | { |
|
7eb028d95972
In msimprpl's mail notifications, change four parallel arrays into
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19607
diff
changeset
|
1306 | const gchar *key; |
|
7eb028d95972
In msimprpl's mail notifications, change four parallel arrays into
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19607
diff
changeset
|
1307 | guint bit; |
|
7eb028d95972
In msimprpl's mail notifications, change four parallel arrays into
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19607
diff
changeset
|
1308 | const gchar *url; |
|
7eb028d95972
In msimprpl's mail notifications, change four parallel arrays into
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19607
diff
changeset
|
1309 | const gchar *text; |
|
7eb028d95972
In msimprpl's mail notifications, change four parallel arrays into
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19607
diff
changeset
|
1310 | } message_types[] = { |
|
7eb028d95972
In msimprpl's mail notifications, change four parallel arrays into
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19607
diff
changeset
|
1311 | { "Mail", MSIM_INBOX_MAIL, "http://messaging.myspace.com/index.cfm?fuseaction=mail.inbox", NULL }, |
|
7eb028d95972
In msimprpl's mail notifications, change four parallel arrays into
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19607
diff
changeset
|
1312 | { "BlogComment", MSIM_INBOX_BLOG_COMMENT, "http://blog.myspace.com/index.cfm?fuseaction=blog", NULL }, |
|
7eb028d95972
In msimprpl's mail notifications, change four parallel arrays into
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19607
diff
changeset
|
1313 | { "ProfileComment", MSIM_INBOX_PROFILE_COMMENT, "http://home.myspace.com/index.cfm?fuseaction=user", NULL }, |
|
7eb028d95972
In msimprpl's mail notifications, change four parallel arrays into
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19607
diff
changeset
|
1314 | { "FriendRequest", MSIM_INBOX_FRIEND_REQUEST, "http://messaging.myspace.com/index.cfm?fuseaction=mail.friendRequests", NULL }, |
|
7eb028d95972
In msimprpl's mail notifications, change four parallel arrays into
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19607
diff
changeset
|
1315 | { "PictureComment", MSIM_INBOX_PICTURE_COMMENT, "http://home.myspace.com/index.cfm?fuseaction=user", NULL } |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1316 | }; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1317 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1318 | /* Can't write _()'d strings in array initializers. Workaround. */ |
|
19608
7eb028d95972
In msimprpl's mail notifications, change four parallel arrays into
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19607
diff
changeset
|
1319 | message_types[0].text = _("New mail messages"); |
|
7eb028d95972
In msimprpl's mail notifications, change four parallel arrays into
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19607
diff
changeset
|
1320 | message_types[1].text = _("New blog comments"); |
|
7eb028d95972
In msimprpl's mail notifications, change four parallel arrays into
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19607
diff
changeset
|
1321 | message_types[2].text = _("New profile comments"); |
|
7eb028d95972
In msimprpl's mail notifications, change four parallel arrays into
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19607
diff
changeset
|
1322 | message_types[3].text = _("New friend requests!"); |
|
7eb028d95972
In msimprpl's mail notifications, change four parallel arrays into
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19607
diff
changeset
|
1323 | message_types[4].text = _("New picture comments"); |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1324 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1325 | g_return_if_fail(reply != NULL); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1326 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1327 | msim_msg_dump("msim_check_inbox_cb: reply=%s\n", reply); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1328 | |
|
19514
9456ceb35a25
Replace msim_parse_body(), which returns a GHashTable * and takes a gchar *,
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19512
diff
changeset
|
1329 | body = msim_msg_get_dictionary(reply, "body"); |
|
9456ceb35a25
Replace msim_parse_body(), which returns a GHashTable * and takes a gchar *,
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19512
diff
changeset
|
1330 | g_return_if_fail(body != NULL); |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1331 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1332 | notification = g_string_new(""); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1333 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1334 | old_inbox_status = session->inbox_status; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1335 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1336 | n = 0; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1337 | |
|
19608
7eb028d95972
In msimprpl's mail notifications, change four parallel arrays into
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19607
diff
changeset
|
1338 | for (i = 0; i < sizeof(message_types) / sizeof(message_types[0]); ++i) { |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1339 | const gchar *key; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1340 | guint bit; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1341 | |
|
19608
7eb028d95972
In msimprpl's mail notifications, change four parallel arrays into
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19607
diff
changeset
|
1342 | key = message_types[i].key; |
|
7eb028d95972
In msimprpl's mail notifications, change four parallel arrays into
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19607
diff
changeset
|
1343 | bit = message_types[i].bit; |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1344 | |
|
19514
9456ceb35a25
Replace msim_parse_body(), which returns a GHashTable * and takes a gchar *,
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19512
diff
changeset
|
1345 | if (msim_msg_get(body, key)) { |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1346 | /* Notify only on when _changes_ from no mail -> has mail |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1347 | * (edge triggered) */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1348 | if (!(session->inbox_status & bit)) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1349 | purple_debug_info("msim", "msim_check_inbox_cb: got %s, at %d\n", |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1350 | key ? key : "(NULL)", n); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1351 | |
|
19608
7eb028d95972
In msimprpl's mail notifications, change four parallel arrays into
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19607
diff
changeset
|
1352 | subjects[n] = message_types[i].text; |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1353 | froms[n] = _("MySpace"); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1354 | tos[n] = session->username; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1355 | /* TODO: append token, web challenge, so automatically logs in. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1356 | * Would also need to free strings because they won't be static |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1357 | */ |
|
19608
7eb028d95972
In msimprpl's mail notifications, change four parallel arrays into
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19607
diff
changeset
|
1358 | urls[n] = message_types[i].url; |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1359 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1360 | ++n; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1361 | } else { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1362 | purple_debug_info("msim", |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1363 | "msim_check_inbox_cb: already notified of %s\n", |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1364 | key ? key : "(NULL)"); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1365 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1366 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1367 | session->inbox_status |= bit; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1368 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1369 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1370 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1371 | if (n) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1372 | purple_debug_info("msim", |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1373 | "msim_check_inbox_cb: notifying of %d\n", n); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1374 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1375 | /* TODO: free strings with callback _if_ change to dynamic (w/ token) */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1376 | purple_notify_emails(session->gc, /* handle */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1377 | n, /* count */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1378 | TRUE, /* detailed */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1379 | subjects, froms, tos, urls, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1380 | NULL, /* PurpleNotifyCloseCallback cb */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1381 | NULL); /* gpointer user_data */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1382 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1383 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1384 | |
|
19514
9456ceb35a25
Replace msim_parse_body(), which returns a GHashTable * and takes a gchar *,
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19512
diff
changeset
|
1385 | msim_msg_free(body); |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1386 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1387 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1388 | /* Send request to check if there is new mail. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1389 | static gboolean |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1390 | msim_check_inbox(gpointer data) |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1391 | { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1392 | MsimSession *session; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1393 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1394 | session = (MsimSession *)data; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1395 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1396 | purple_debug_info("msim", "msim_check_inbox: checking mail\n"); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1397 | g_return_val_if_fail(msim_send(session, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1398 | "persist", MSIM_TYPE_INTEGER, 1, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1399 | "sesskey", MSIM_TYPE_INTEGER, session->sesskey, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1400 | "cmd", MSIM_TYPE_INTEGER, MSIM_CMD_GET, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1401 | "dsn", MSIM_TYPE_INTEGER, MG_CHECK_MAIL_DSN, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1402 | "lid", MSIM_TYPE_INTEGER, MG_CHECK_MAIL_LID, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1403 | "uid", MSIM_TYPE_INTEGER, session->userid, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1404 | "rid", MSIM_TYPE_INTEGER, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1405 | msim_new_reply_callback(session, msim_check_inbox_cb, NULL), |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1406 | "body", MSIM_TYPE_STRING, g_strdup(""), |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1407 | NULL), TRUE); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1408 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1409 | /* Always return true, so that we keep checking for mail. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1410 | return TRUE; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1411 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1412 | |
|
19741
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1413 | #ifdef MSIM_CHECK_NEWER_VERSION |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1414 | /** Callback for when a currentversion.txt has been downloaded. */ |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1415 | static void |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1416 | msim_check_newer_version_cb(PurpleUtilFetchUrlData *url_data, |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1417 | gpointer user_data, |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1418 | const gchar *url_text, |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1419 | gsize len, |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1420 | const gchar *error_message) |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1421 | { |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1422 | GKeyFile *keyfile; |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1423 | GError *error; |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1424 | GString *data; |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1425 | gchar *newest_filever; |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1426 | |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1427 | if (!url_text) { |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1428 | purple_debug_info("msim_check_newer_version_cb", |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1429 | "got error: %s\n", error_message); |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1430 | return; |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1431 | } |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1432 | |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1433 | purple_debug_info("msim_check_newer_version_cb", |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1434 | "url_text=%s\n", url_text ? url_text : "(NULL)"); |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1435 | |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1436 | /* Prepend [group] so that GKeyFile can parse it (requires a group). */ |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1437 | data = g_string_new(url_text); |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1438 | purple_debug_info("msim", "data=%s\n", data->str |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1439 | ? data->str : "(NULL)"); |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1440 | data = g_string_prepend(data, "[group]\n"); |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1441 | |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1442 | purple_debug_info("msim", "data=%s\n", data->str |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1443 | ? data->str : "(NULL)"); |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1444 | |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1445 | /* url_text is variable=data\n... */ |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1446 | |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1447 | /* Check FILEVER, 1.0.716.0. 716 is build, MSIM_CLIENT_VERSION */ |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1448 | /* New (english) version can be downloaded from SETUPURL+SETUPFILE */ |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1449 | |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1450 | error = NULL; |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1451 | keyfile = g_key_file_new(); |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1452 | |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1453 | /* Default list seperator is ;, but currentversion.txt doesn't have |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1454 | * these, so set to an unused character to avoid parsing problems. */ |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1455 | g_key_file_set_list_separator(keyfile, '\0'); |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1456 | |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1457 | g_key_file_load_from_data(keyfile, data->str, data->len, |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1458 | G_KEY_FILE_NONE, &error); |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1459 | g_string_free(data, TRUE); |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1460 | |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1461 | if (error != NULL) { |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1462 | purple_debug_info("msim_check_newer_version_cb", |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1463 | "couldn't parse, error: %d %d %s\n", |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1464 | error->domain, error->code, error->message); |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1465 | g_error_free(error); |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1466 | return; |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1467 | } |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1468 | |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1469 | gchar **ks; |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1470 | guint n; |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1471 | ks = g_key_file_get_keys(keyfile, "group", &n, NULL); |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1472 | purple_debug_info("msim", "n=%d\n", n); |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1473 | guint i; |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1474 | for (i = 0; ks[i] != NULL; ++i) |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1475 | { |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1476 | purple_debug_info("msim", "%d=%s\n", i, ks[i]); |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1477 | } |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1478 | |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1479 | newest_filever = g_key_file_get_string(keyfile, "group", |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1480 | "FILEVER", &error); |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1481 | |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1482 | purple_debug_info("msim_check_newer_version_cb", |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1483 | "newest filever: %s\n", newest_filever ? |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1484 | newest_filever : "(NULL)"); |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1485 | if (error != NULL) { |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1486 | purple_debug_info("msim_check_newer_version_cb", |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1487 | "error: %d %d %s\n", |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1488 | error->domain, error->code, error->message); |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1489 | g_error_free(error); |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1490 | } |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1491 | |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1492 | g_key_file_free(keyfile); |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1493 | |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1494 | exit(0); |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1495 | } |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1496 | #endif |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
1497 | |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1498 | /** Called when the session key arrives. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1499 | static gboolean |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1500 | msim_we_are_logged_on(MsimSession *session, MsimMessage *msg) |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1501 | { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1502 | MsimMessage *body; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1503 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1504 | g_return_val_if_fail(MSIM_SESSION_VALID(session), FALSE); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1505 | g_return_val_if_fail(msg != NULL, FALSE); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1506 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1507 | session->sesskey = msim_msg_get_integer(msg, "sesskey"); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1508 | purple_debug_info("msim", "SESSKEY=<%d>\n", session->sesskey); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1509 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1510 | /* What is proof? Used to be uid, but now is 52 base64'd bytes... */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1511 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1512 | /* Comes with: proof,profileid,userid,uniquenick -- all same values |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1513 | * some of the time, but can vary. This is our own user ID. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1514 | session->userid = msim_msg_get_integer(msg, "userid"); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1515 | |
|
19620
238f24594c04
Add msim_uri_handler() to handle myim: URLs, sendIM and addContact commands.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19619
diff
changeset
|
1516 | /* Save uid to account so this account can be looked up by uid. */ |
|
238f24594c04
Add msim_uri_handler() to handle myim: URLs, sendIM and addContact commands.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19619
diff
changeset
|
1517 | purple_account_set_int(session->account, "uid", session->userid); |
|
238f24594c04
Add msim_uri_handler() to handle myim: URLs, sendIM and addContact commands.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19619
diff
changeset
|
1518 | |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1519 | /* Not sure what profileid is used for. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1520 | if (msim_msg_get_integer(msg, "profileid") != session->userid) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1521 | msim_unrecognized(session, msg, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1522 | "Profile ID didn't match user ID, don't know why"); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1523 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1524 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1525 | /* We now know are our own username, only after we're logged in.. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1526 | * which is weird, but happens because you login with your email |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1527 | * address and not username. Will be freed in msim_session_destroy(). */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1528 | session->username = msim_msg_get_string(msg, "uniquenick"); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1529 | |
|
19634
30bbe39b35db
In msimprpl: if no local alias is set, set it to the username on sign-on.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19633
diff
changeset
|
1530 | /* If a local alias wasn't set, set it to user's username. */ |
|
30bbe39b35db
In msimprpl: if no local alias is set, set it to the username on sign-on.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19633
diff
changeset
|
1531 | if (!session->account->alias || !strlen(session->account->alias)) |
|
19775
6c3745c29a5d
Set our alias using the appropriate function. This makes a copy of
Mark Doliner <markdoliner@pidgin.im>
parents:
19737
diff
changeset
|
1532 | purple_account_set_alias(session->account, session->username); |
|
19634
30bbe39b35db
In msimprpl: if no local alias is set, set it to the username on sign-on.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19633
diff
changeset
|
1533 | |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1534 | /* The session is now set up, ready to be connected. This emits the |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1535 | * signedOn signal, so clients can now do anything with msimprpl, and |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1536 | * we're ready for it (session key, userid, username all setup). */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1537 | purple_connection_update_progress(session->gc, _("Connected"), 3, 4); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1538 | purple_connection_set_state(session->gc, PURPLE_CONNECTED); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1539 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1540 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1541 | /* Additional post-connect operations */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1542 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1543 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1544 | if (msim_msg_get_integer(msg, "uniquenick") == session->userid) { |
|
19832
84b69b21672b
Patch from QuLogic. Fixes #2903 ('Missing newlines in debug messages.')
Sadrul Habib Chowdhury <sadrul@pidgin.im>
parents:
19816
diff
changeset
|
1545 | purple_debug_info("msim_we_are_logged_on", "TODO: pick username\n"); |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1546 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1547 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1548 | body = msim_msg_new( |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1549 | "UserID", MSIM_TYPE_INTEGER, session->userid, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1550 | NULL); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1551 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1552 | /* Request IM info about ourself. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1553 | msim_send(session, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1554 | "persist", MSIM_TYPE_STRING, g_strdup("persist"), |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1555 | "sesskey", MSIM_TYPE_INTEGER, session->sesskey, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1556 | "dsn", MSIM_TYPE_INTEGER, MG_OWN_MYSPACE_INFO_DSN, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1557 | "uid", MSIM_TYPE_INTEGER, session->userid, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1558 | "lid", MSIM_TYPE_INTEGER, MG_OWN_MYSPACE_INFO_LID, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1559 | "rid", MSIM_TYPE_INTEGER, session->next_rid++, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1560 | "body", MSIM_TYPE_DICTIONARY, body, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1561 | NULL); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1562 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1563 | /* Request MySpace info about ourself. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1564 | msim_send(session, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1565 | "persist", MSIM_TYPE_STRING, g_strdup("persist"), |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1566 | "sesskey", MSIM_TYPE_INTEGER, session->sesskey, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1567 | "dsn", MSIM_TYPE_INTEGER, MG_OWN_IM_INFO_DSN, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1568 | "uid", MSIM_TYPE_INTEGER, session->userid, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1569 | "lid", MSIM_TYPE_INTEGER, MG_OWN_IM_INFO_LID, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1570 | "rid", MSIM_TYPE_INTEGER, session->next_rid++, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1571 | "body", MSIM_TYPE_STRING, g_strdup(""), |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1572 | NULL); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1573 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1574 | /* TODO: set options (persist cmd=514,dsn=1,lid=10) */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1575 | /* TODO: set blocklist */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1576 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1577 | /* Notify servers of our current status. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1578 | purple_debug_info("msim", "msim_we_are_logged_on: notifying servers of status\n"); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1579 | msim_set_status(session->account, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1580 | purple_account_get_active_status(session->account)); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1581 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1582 | /* TODO: setinfo */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1583 | /* |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1584 | body = msim_msg_new( |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1585 | "TotalFriends", MSIM_TYPE_INTEGER, 666, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1586 | NULL); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1587 | msim_send(session, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1588 | "setinfo", MSIM_TYPE_BOOLEAN, TRUE, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1589 | "sesskey", MSIM_TYPE_INTEGER, session->sesskey, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1590 | "info", MSIM_TYPE_DICTIONARY, body, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1591 | NULL); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1592 | */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1593 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1594 | /* Disable due to problems with timeouts. TODO: fix. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1595 | #ifdef MSIM_USE_KEEPALIVE |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1596 | purple_timeout_add(MSIM_KEEPALIVE_INTERVAL_CHECK, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1597 | (GSourceFunc)msim_check_alive, session); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1598 | #endif |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1599 | |
|
19640
48e64a5069da
On login, get contacts from server using msim_get_contact_list().
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19634
diff
changeset
|
1600 | /* Check mail if they want to. */ |
|
19621
a56a4af5af49
Only check for mail if "New mail notifications" is enabled in account options.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19620
diff
changeset
|
1601 | if (purple_account_get_check_mail(session->account)) { |
|
a56a4af5af49
Only check for mail if "New mail notifications" is enabled in account options.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19620
diff
changeset
|
1602 | purple_timeout_add(MSIM_MAIL_INTERVAL_CHECK, |
|
a56a4af5af49
Only check for mail if "New mail notifications" is enabled in account options.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19620
diff
changeset
|
1603 | (GSourceFunc)msim_check_inbox, session); |
|
a56a4af5af49
Only check for mail if "New mail notifications" is enabled in account options.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19620
diff
changeset
|
1604 | msim_check_inbox(session); |
|
a56a4af5af49
Only check for mail if "New mail notifications" is enabled in account options.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19620
diff
changeset
|
1605 | } |
|
a56a4af5af49
Only check for mail if "New mail notifications" is enabled in account options.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19620
diff
changeset
|
1606 | |
|
19640
48e64a5069da
On login, get contacts from server using msim_get_contact_list().
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19634
diff
changeset
|
1607 | msim_get_contact_list(session, MSIM_CONTACT_LIST_INITIAL_FRIENDS); |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1608 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1609 | return TRUE; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1610 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1611 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1612 | /** |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1613 | * Process a message. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1614 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1615 | * @param session |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1616 | * @param msg A message from the server, ready for processing (possibly with resolved username information attached). Caller frees. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1617 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1618 | * @return TRUE if successful. FALSE if processing failed. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1619 | */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1620 | static gboolean |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1621 | msim_process(MsimSession *session, MsimMessage *msg) |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1622 | { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1623 | g_return_val_if_fail(session != NULL, FALSE); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1624 | g_return_val_if_fail(msg != NULL, FALSE); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1625 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1626 | #ifdef MSIM_DEBUG_MSG |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1627 | msim_msg_dump("ready to process: %s\n", msg); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1628 | #endif |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1629 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1630 | if (msim_msg_get_integer(msg, "lc") == 1) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1631 | return msim_login_challenge(session, msg); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1632 | } else if (msim_msg_get_integer(msg, "lc") == 2) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1633 | return msim_we_are_logged_on(session, msg); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1634 | } else if (msim_msg_get(msg, "bm")) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1635 | return msim_incoming_bm(session, msg); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1636 | } else if (msim_msg_get(msg, "rid")) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1637 | return msim_process_reply(session, msg); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1638 | } else if (msim_msg_get(msg, "error")) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1639 | return msim_error(session, msg); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1640 | } else if (msim_msg_get(msg, "ka")) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1641 | return TRUE; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1642 | } else { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1643 | msim_unrecognized(session, msg, "in msim_process"); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1644 | return FALSE; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1645 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1646 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1647 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1648 | /** Process the initial server information from the server. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1649 | static gboolean |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1650 | msim_process_server_info(MsimSession *session, MsimMessage *msg) |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1651 | { |
|
19514
9456ceb35a25
Replace msim_parse_body(), which returns a GHashTable * and takes a gchar *,
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19512
diff
changeset
|
1652 | MsimMessage *body; |
|
9456ceb35a25
Replace msim_parse_body(), which returns a GHashTable * and takes a gchar *,
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19512
diff
changeset
|
1653 | |
|
9456ceb35a25
Replace msim_parse_body(), which returns a GHashTable * and takes a gchar *,
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19512
diff
changeset
|
1654 | body = msim_msg_get_dictionary(msg, "body"); |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1655 | g_return_val_if_fail(body != NULL, FALSE); |
|
19514
9456ceb35a25
Replace msim_parse_body(), which returns a GHashTable * and takes a gchar *,
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19512
diff
changeset
|
1656 | |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1657 | /* Example body: |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1658 | AdUnitRefreshInterval=10. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1659 | AlertPollInterval=360. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1660 | AllowChatRoomEmoticonSharing=False. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1661 | ChatRoomUserIDs=78744676;163733130;1300326231;123521495;142663391. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1662 | CurClientVersion=673. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1663 | EnableIMBrowse=True. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1664 | EnableIMStuffAvatars=False. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1665 | EnableIMStuffZaps=False. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1666 | MaxAddAllFriends=100. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1667 | MaxContacts=1000. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1668 | MinClientVersion=594. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1669 | MySpaceIM_ENGLISH=78744676. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1670 | MySpaceNowTimer=720. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1671 | PersistenceDataTimeout=900. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1672 | UseWebChallenge=1. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1673 | WebTicketGoHome=False |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1674 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1675 | Anything useful? TODO: use what is useful, and use it. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1676 | */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1677 | purple_debug_info("msim_process_server_info", |
|
19514
9456ceb35a25
Replace msim_parse_body(), which returns a GHashTable * and takes a gchar *,
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19512
diff
changeset
|
1678 | "maximum contacts: %d\n", |
|
9456ceb35a25
Replace msim_parse_body(), which returns a GHashTable * and takes a gchar *,
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19512
diff
changeset
|
1679 | msim_msg_get_integer(body, "MaxContacts")); |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1680 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1681 | session->server_info = body; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1682 | /* session->server_info freed in msim_session_destroy */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1683 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1684 | return TRUE; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1685 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1686 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1687 | /** Process a web challenge, used to login to the web site. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1688 | static gboolean |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1689 | msim_web_challenge(MsimSession *session, MsimMessage *msg) |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1690 | { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1691 | /* TODO: web challenge, store token */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1692 | return FALSE; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1693 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1694 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1695 | /** |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1696 | * Process a persistance message reply from the server. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1697 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1698 | * @param session |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1699 | * @param msg Message reply from server. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1700 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1701 | * @return TRUE if successful. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1702 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1703 | * msim_lookup_user sets callback for here |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1704 | */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1705 | static gboolean |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1706 | msim_process_reply(MsimSession *session, MsimMessage *msg) |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1707 | { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1708 | MSIM_USER_LOOKUP_CB cb; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1709 | gpointer data; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1710 | guint rid, cmd, dsn, lid; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1711 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1712 | g_return_val_if_fail(MSIM_SESSION_VALID(session), FALSE); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1713 | g_return_val_if_fail(msg != NULL, FALSE); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1714 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1715 | msim_store_user_info(session, msg, NULL); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1716 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1717 | rid = msim_msg_get_integer(msg, "rid"); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1718 | cmd = msim_msg_get_integer(msg, "cmd"); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1719 | dsn = msim_msg_get_integer(msg, "dsn"); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1720 | lid = msim_msg_get_integer(msg, "lid"); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1721 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1722 | /* Unsolicited messages */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1723 | if (cmd == (MSIM_CMD_BIT_REPLY | MSIM_CMD_GET)) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1724 | if (dsn == MG_SERVER_INFO_DSN && lid == MG_SERVER_INFO_LID) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1725 | return msim_process_server_info(session, msg); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1726 | } else if (dsn == MG_WEB_CHALLENGE_DSN && lid == MG_WEB_CHALLENGE_LID) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1727 | return msim_web_challenge(session, msg); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1728 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1729 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1730 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1731 | /* If a callback is registered for this userid lookup, call it. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1732 | cb = g_hash_table_lookup(session->user_lookup_cb, GUINT_TO_POINTER(rid)); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1733 | data = g_hash_table_lookup(session->user_lookup_cb_data, GUINT_TO_POINTER(rid)); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1734 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1735 | if (cb) { |
|
19518
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
1736 | purple_debug_info("msim", "msim_process_reply: calling callback now\n"); |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
1737 | msim_msg_dump("for msg=%s\n", msg); |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1738 | /* Clone message, so that the callback 'cb' can use it (needs to free it also). */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1739 | cb(session, msim_msg_clone(msg), data); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1740 | g_hash_table_remove(session->user_lookup_cb, GUINT_TO_POINTER(rid)); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1741 | g_hash_table_remove(session->user_lookup_cb_data, GUINT_TO_POINTER(rid)); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1742 | } else { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1743 | purple_debug_info("msim", |
|
19518
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
1744 | "msim_process_reply: no callback for rid %d\n", rid); |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1745 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1746 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1747 | return TRUE; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1748 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1749 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1750 | /** |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1751 | * Handle an error from the server. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1752 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1753 | * @param session |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1754 | * @param msg The message. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1755 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1756 | * @return TRUE if successfully reported error. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1757 | */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1758 | static gboolean |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1759 | msim_error(MsimSession *session, MsimMessage *msg) |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1760 | { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1761 | gchar *errmsg, *full_errmsg; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1762 | guint err; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1763 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1764 | g_return_val_if_fail(MSIM_SESSION_VALID(session), FALSE); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1765 | g_return_val_if_fail(msg != NULL, FALSE); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1766 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1767 | err = msim_msg_get_integer(msg, "err"); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1768 | errmsg = msim_msg_get_string(msg, "errmsg"); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1769 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1770 | full_errmsg = g_strdup_printf(_("Protocol error, code %d: %s"), err, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1771 | errmsg ? errmsg : "no 'errmsg' given"); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1772 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1773 | g_free(errmsg); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1774 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1775 | purple_debug_info("msim", "msim_error (sesskey=%d): %s\n", |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1776 | session->sesskey, full_errmsg); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1777 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1778 | /* Destroy session if fatal. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1779 | if (msim_msg_get(msg, "fatal")) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1780 | purple_debug_info("msim", "fatal error, closing\n"); |
|
19816
bbc1ca913085
Ka-Hing reminded me that we should set the password to NULL when
Mark Doliner <markdoliner@pidgin.im>
parents:
19815
diff
changeset
|
1781 | if (err == 260) { |
|
19815
204fb857496e
Three small changes:
Mark Doliner <markdoliner@pidgin.im>
parents:
19790
diff
changeset
|
1782 | /* Incorrect password */ |
|
204fb857496e
Three small changes:
Mark Doliner <markdoliner@pidgin.im>
parents:
19790
diff
changeset
|
1783 | session->gc->wants_to_die = TRUE; |
|
19816
bbc1ca913085
Ka-Hing reminded me that we should set the password to NULL when
Mark Doliner <markdoliner@pidgin.im>
parents:
19815
diff
changeset
|
1784 | if (!purple_account_get_remember_password(session->account)) |
|
bbc1ca913085
Ka-Hing reminded me that we should set the password to NULL when
Mark Doliner <markdoliner@pidgin.im>
parents:
19815
diff
changeset
|
1785 | purple_account_set_password(session->account, NULL); |
|
bbc1ca913085
Ka-Hing reminded me that we should set the password to NULL when
Mark Doliner <markdoliner@pidgin.im>
parents:
19815
diff
changeset
|
1786 | } |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1787 | purple_connection_error(session->gc, full_errmsg); |
|
19815
204fb857496e
Three small changes:
Mark Doliner <markdoliner@pidgin.im>
parents:
19790
diff
changeset
|
1788 | } else { |
|
204fb857496e
Three small changes:
Mark Doliner <markdoliner@pidgin.im>
parents:
19790
diff
changeset
|
1789 | purple_notify_error(session->account, g_strdup(_("MySpaceIM Error")), |
|
204fb857496e
Three small changes:
Mark Doliner <markdoliner@pidgin.im>
parents:
19790
diff
changeset
|
1790 | full_errmsg, NULL); |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1791 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1792 | |
|
19815
204fb857496e
Three small changes:
Mark Doliner <markdoliner@pidgin.im>
parents:
19790
diff
changeset
|
1793 | g_free(full_errmsg); |
|
204fb857496e
Three small changes:
Mark Doliner <markdoliner@pidgin.im>
parents:
19790
diff
changeset
|
1794 | |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1795 | return TRUE; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1796 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1797 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1798 | /** |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1799 | * Process incoming status messages. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1800 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1801 | * @param session |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1802 | * @param msg Status update message. Caller frees. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1803 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1804 | * @return TRUE if successful. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1805 | */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1806 | static gboolean |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1807 | msim_incoming_status(MsimSession *session, MsimMessage *msg) |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1808 | { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1809 | PurpleBuddyList *blist; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1810 | MsimUser *user; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1811 | GList *list; |
|
19731
844a19c41487
Treat status messages as the plaintext that they are.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19730
diff
changeset
|
1812 | gchar *status_headline, *status_headline_escaped; |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1813 | gint status_code, purple_status_code; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1814 | gchar *username; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1815 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1816 | g_return_val_if_fail(MSIM_SESSION_VALID(session), FALSE); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1817 | g_return_val_if_fail(msg != NULL, FALSE); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1818 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1819 | msim_msg_dump("msim_status msg=%s\n", msg); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1820 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1821 | /* Helpfully looked up by msim_incoming_resolve() for us. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1822 | username = msim_msg_get_string(msg, "_username"); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1823 | g_return_val_if_fail(username != NULL, FALSE); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1824 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1825 | { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1826 | gchar *ss; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1827 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1828 | ss = msim_msg_get_string(msg, "msg"); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1829 | purple_debug_info("msim", |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1830 | "msim_status: updating status for <%s> to <%s>\n", |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1831 | username, ss ? ss : "(NULL)"); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1832 | g_free(ss); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1833 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1834 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1835 | /* Example fields: |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1836 | * |s|0|ss|Offline |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1837 | * |s|1|ss|:-)|ls||ip|0|p|0 |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1838 | */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1839 | list = msim_msg_get_list(msg, "msg"); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1840 | |
|
19615
27d6e6c234c4
Now that MsimMessageElement's are more accessible outside message.c,
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19608
diff
changeset
|
1841 | status_code = msim_msg_get_integer_from_element(g_list_nth_data(list, MSIM_STATUS_ORDINAL_ONLINE)); |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1842 | purple_debug_info("msim", "msim_status: %s's status code = %d\n", username, status_code); |
|
19615
27d6e6c234c4
Now that MsimMessageElement's are more accessible outside message.c,
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19608
diff
changeset
|
1843 | status_headline = msim_msg_get_string_from_element(g_list_nth_data(list, MSIM_STATUS_ORDINAL_HEADLINE)); |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1844 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1845 | blist = purple_get_blist(); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1846 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1847 | /* Add buddy if not found */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1848 | user = msim_find_user(session, username); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1849 | if (!user) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1850 | PurpleBuddy *buddy; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1851 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1852 | purple_debug_info("msim", |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1853 | "msim_status: making new buddy for %s\n", username); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1854 | buddy = purple_buddy_new(session->account, username, NULL); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1855 | purple_blist_add_buddy(buddy, NULL, NULL, NULL); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1856 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1857 | user = msim_get_user_from_buddy(buddy); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1858 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1859 | /* All buddies on list should have 'uid' integer associated with them. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1860 | purple_blist_node_set_int(&buddy->node, "UserID", msim_msg_get_integer(msg, "f")); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1861 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1862 | msim_store_user_info(session, msg, NULL); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1863 | } else { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1864 | purple_debug_info("msim", "msim_status: found buddy %s\n", username); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1865 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1866 | |
|
19731
844a19c41487
Treat status messages as the plaintext that they are.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19730
diff
changeset
|
1867 | /* The status headline is plaintext, but libpurple treats it as HTML, |
|
844a19c41487
Treat status messages as the plaintext that they are.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19730
diff
changeset
|
1868 | * so escape any HTML characters to their entity equivalents. */ |
|
844a19c41487
Treat status messages as the plaintext that they are.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19730
diff
changeset
|
1869 | status_headline_escaped = g_markup_escape_text(status_headline, strlen(status_headline)); |
|
844a19c41487
Treat status messages as the plaintext that they are.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19730
diff
changeset
|
1870 | g_free(status_headline); |
|
844a19c41487
Treat status messages as the plaintext that they are.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19730
diff
changeset
|
1871 | |
|
844a19c41487
Treat status messages as the plaintext that they are.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19730
diff
changeset
|
1872 | if (user->headline) |
|
844a19c41487
Treat status messages as the plaintext that they are.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19730
diff
changeset
|
1873 | g_free(user->headline); |
|
844a19c41487
Treat status messages as the plaintext that they are.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19730
diff
changeset
|
1874 | |
|
19615
27d6e6c234c4
Now that MsimMessageElement's are more accessible outside message.c,
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19608
diff
changeset
|
1875 | /* don't copy; let the MsimUser own the headline, memory-wise */ |
|
19731
844a19c41487
Treat status messages as the plaintext that they are.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19730
diff
changeset
|
1876 | user->headline = status_headline_escaped; |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1877 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1878 | /* Set user status */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1879 | switch (status_code) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1880 | case MSIM_STATUS_CODE_OFFLINE_OR_HIDDEN: |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1881 | purple_status_code = PURPLE_STATUS_OFFLINE; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1882 | break; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1883 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1884 | case MSIM_STATUS_CODE_ONLINE: |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1885 | purple_status_code = PURPLE_STATUS_AVAILABLE; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1886 | break; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1887 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1888 | case MSIM_STATUS_CODE_AWAY: |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1889 | purple_status_code = PURPLE_STATUS_AWAY; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1890 | break; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1891 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1892 | case MSIM_STATUS_CODE_IDLE: |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1893 | /* will be handled below */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1894 | purple_status_code = -1; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1895 | break; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1896 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1897 | default: |
|
19607
0b72b396dbcd
Lookup a user's information when their status changes to anything but
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19606
diff
changeset
|
1898 | purple_debug_info("msim", "msim_status for %s, unknown status code %d, treating as available\n", |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1899 | username, status_code); |
|
19607
0b72b396dbcd
Lookup a user's information when their status changes to anything but
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19606
diff
changeset
|
1900 | purple_status_code = PURPLE_STATUS_AVAILABLE; |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1901 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1902 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1903 | purple_prpl_got_user_status(session->account, username, purple_primitive_get_id_from_type(purple_status_code), NULL); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1904 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1905 | if (status_code == MSIM_STATUS_CODE_IDLE) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1906 | purple_debug_info("msim", "msim_status: got idle: %s\n", username); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1907 | purple_prpl_got_user_idle(session->account, username, TRUE, time(NULL)); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1908 | } else { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1909 | /* All other statuses indicate going back to non-idle. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1910 | purple_prpl_got_user_idle(session->account, username, FALSE, time(NULL)); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1911 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1912 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1913 | #ifdef MSIM_SEND_CLIENT_VERSION |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1914 | if (status_code == MSIM_STATUS_CODE_ONLINE) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1915 | /* Secretly whisper to unofficial clients our own version as they come online */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1916 | msim_send_unofficial_client(session, username); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1917 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1918 | #endif |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1919 | |
|
19607
0b72b396dbcd
Lookup a user's information when their status changes to anything but
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19606
diff
changeset
|
1920 | if (status_code != MSIM_STATUS_CODE_OFFLINE_OR_HIDDEN) { |
|
0b72b396dbcd
Lookup a user's information when their status changes to anything but
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19606
diff
changeset
|
1921 | /* Get information when they come online. |
|
0b72b396dbcd
Lookup a user's information when their status changes to anything but
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19606
diff
changeset
|
1922 | * TODO: periodically refresh? |
|
0b72b396dbcd
Lookup a user's information when their status changes to anything but
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19606
diff
changeset
|
1923 | */ |
|
0b72b396dbcd
Lookup a user's information when their status changes to anything but
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19606
diff
changeset
|
1924 | purple_debug_info("msim_incoming_status", "%s came online, looking up\n", username); |
|
0b72b396dbcd
Lookup a user's information when their status changes to anything but
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19606
diff
changeset
|
1925 | msim_lookup_user(session, username, NULL, NULL); |
|
0b72b396dbcd
Lookup a user's information when their status changes to anything but
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19606
diff
changeset
|
1926 | } |
|
0b72b396dbcd
Lookup a user's information when their status changes to anything but
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19606
diff
changeset
|
1927 | |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1928 | g_free(username); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1929 | msim_msg_list_free(list); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1930 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1931 | return TRUE; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1932 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1933 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1934 | /** Add a buddy to user's buddy list. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1935 | void |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1936 | msim_add_buddy(PurpleConnection *gc, PurpleBuddy *buddy, PurpleGroup *group) |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1937 | { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1938 | MsimSession *session; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1939 | MsimMessage *msg; |
|
19740
17a9a2e5ef4a
Add uid field to add buddy persistance request. Now adding buddies to the
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19737
diff
changeset
|
1940 | MsimMessage *msg_persist; |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1941 | MsimMessage *body; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1942 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1943 | session = (MsimSession *)gc->proto_data; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1944 | purple_debug_info("msim", "msim_add_buddy: want to add %s to %s\n", |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1945 | buddy->name, (group && group->name) ? group->name : "(no group)"); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1946 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1947 | msg = msim_msg_new( |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1948 | "addbuddy", MSIM_TYPE_BOOLEAN, TRUE, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1949 | "sesskey", MSIM_TYPE_INTEGER, session->sesskey, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1950 | /* "newprofileid" will be inserted here with uid. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1951 | "reason", MSIM_TYPE_STRING, g_strdup(""), |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1952 | NULL); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1953 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1954 | if (!msim_postprocess_outgoing(session, msg, buddy->name, "newprofileid", "reason")) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1955 | purple_notify_error(NULL, NULL, _("Failed to add buddy"), _("'addbuddy' command failed.")); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1956 | msim_msg_free(msg); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1957 | return; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1958 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1959 | msim_msg_free(msg); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1960 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1961 | /* TODO: if addbuddy fails ('error' message is returned), delete added buddy from |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1962 | * buddy list since Purple adds it locally. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1963 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1964 | body = msim_msg_new( |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1965 | "ContactID", MSIM_TYPE_STRING, g_strdup("<uid>"), |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1966 | "GroupName", MSIM_TYPE_STRING, g_strdup(group->name), |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1967 | "Position", MSIM_TYPE_INTEGER, 1000, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1968 | "Visibility", MSIM_TYPE_INTEGER, 1, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1969 | "NickName", MSIM_TYPE_STRING, g_strdup(""), |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1970 | "NameSelect", MSIM_TYPE_INTEGER, 0, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1971 | NULL); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1972 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1973 | /* TODO: Update blocklist. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1974 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1975 | msg_persist = msim_msg_new( |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1976 | "persist", MSIM_TYPE_INTEGER, 1, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1977 | "sesskey", MSIM_TYPE_INTEGER, session->sesskey, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1978 | "cmd", MSIM_TYPE_INTEGER, MSIM_CMD_BIT_ACTION | MSIM_CMD_PUT, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1979 | "dsn", MSIM_TYPE_INTEGER, MC_CONTACT_INFO_DSN, |
|
19740
17a9a2e5ef4a
Add uid field to add buddy persistance request. Now adding buddies to the
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19737
diff
changeset
|
1980 | "uid", MSIM_TYPE_INTEGER, session->userid, |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1981 | "lid", MSIM_TYPE_INTEGER, MC_CONTACT_INFO_LID, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1982 | /* TODO: Use msim_new_reply_callback to get rid. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1983 | "rid", MSIM_TYPE_INTEGER, session->next_rid++, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1984 | "body", MSIM_TYPE_DICTIONARY, body, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1985 | NULL); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1986 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1987 | if (!msim_postprocess_outgoing(session, msg_persist, buddy->name, "body", NULL)) |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1988 | { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1989 | purple_notify_error(NULL, NULL, _("Failed to add buddy"), _("persist command failed")); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1990 | msim_msg_free(msg_persist); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1991 | return; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1992 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1993 | msim_msg_free(msg_persist); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1994 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1995 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1996 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1997 | /** Perform actual postprocessing on a message, adding userid as specified. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1998 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
1999 | * @param msg The message to postprocess. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2000 | * @param uid_before Name of field where to insert new field before, or NULL for end. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2001 | * @param uid_field_name Name of field to add uid to. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2002 | * @param uid The userid to insert. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2003 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2004 | * If the field named by uid_field_name already exists, then its string contents will |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2005 | * be used for the field, except "<uid>" will be replaced by the userid. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2006 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2007 | * If the field named by uid_field_name does not exist, it will be added before the |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2008 | * field named by uid_before, as an integer, with the userid. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2009 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2010 | * Does not handle sending, or scheduling userid lookup. For that, see msim_postprocess_outgoing(). |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2011 | */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2012 | static MsimMessage * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2013 | msim_do_postprocessing(MsimMessage *msg, const gchar *uid_before, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2014 | const gchar *uid_field_name, guint uid) |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2015 | { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2016 | msim_msg_dump("msim_do_postprocessing msg: %s\n", msg); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2017 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2018 | /* First, check - if the field already exists, replace <uid> within it */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2019 | if (msim_msg_get(msg, uid_field_name)) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2020 | MsimMessageElement *elem; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2021 | gchar *fmt_string; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2022 | gchar *uid_str, *new_str; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2023 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2024 | /* Warning: this is a delicate, but safe, operation */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2025 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2026 | elem = msim_msg_get(msg, uid_field_name); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2027 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2028 | /* Get the packed element, flattening it. This allows <uid> to be |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2029 | * replaced within nested data structures, since the replacement is done |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2030 | * on the linear, packed data, not on a complicated data structure. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2031 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2032 | * For example, if the field was originally a dictionary or a list, you |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2033 | * would have to iterate over all the items in it to see what needs to |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2034 | * be replaced. But by packing it first, the <uid> marker is easily replaced |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2035 | * just by a string replacement. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2036 | */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2037 | fmt_string = msim_msg_pack_element_data(elem); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2038 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2039 | uid_str = g_strdup_printf("%d", uid); |
|
19644
a36c0623d540
Replace homegrown str_replace() with purple_strreplace(), after discovering it.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19640
diff
changeset
|
2040 | new_str = purple_strreplace(fmt_string, "<uid>", uid_str); |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2041 | g_free(uid_str); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2042 | g_free(fmt_string); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2043 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2044 | /* Free the old element data */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2045 | msim_msg_free_element_data(elem->data); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2046 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2047 | /* Replace it with our new data */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2048 | elem->data = new_str; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2049 | elem->type = MSIM_TYPE_RAW; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2050 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2051 | } else { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2052 | /* Otherwise, insert new field into outgoing message. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2053 | msg = msim_msg_insert_before(msg, uid_before, uid_field_name, MSIM_TYPE_INTEGER, GUINT_TO_POINTER(uid)); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2054 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2055 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2056 | msim_msg_dump("msim_postprocess_outgoing_cb: postprocessed msg=%s\n", msg); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2057 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2058 | return msg; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2059 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2060 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2061 | /** Callback for msim_postprocess_outgoing() to add a userid to a message, and send it (once receiving userid). |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2062 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2063 | * @param session |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2064 | * @param userinfo The user information reply message, containing the user ID |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2065 | * @param data The message to postprocess and send. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2066 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2067 | * The data message should contain these fields: |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2068 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2069 | * _uid_field_name: string, name of field to add with userid from userinfo message |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2070 | * _uid_before: string, name of field before field to insert, or NULL for end |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2071 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2072 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2073 | */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2074 | static void |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2075 | msim_postprocess_outgoing_cb(MsimSession *session, MsimMessage *userinfo, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2076 | gpointer data) |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2077 | { |
|
19527
039fcd700802
If a username cannot be looked up in postprocessing, throw up an error.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19519
diff
changeset
|
2078 | gchar *uid_field_name, *uid_before, *username; |
|
19514
9456ceb35a25
Replace msim_parse_body(), which returns a GHashTable * and takes a gchar *,
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19512
diff
changeset
|
2079 | guint uid; |
|
9456ceb35a25
Replace msim_parse_body(), which returns a GHashTable * and takes a gchar *,
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19512
diff
changeset
|
2080 | MsimMessage *msg, *body; |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2081 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2082 | msg = (MsimMessage *)data; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2083 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2084 | msim_msg_dump("msim_postprocess_outgoing_cb() got msg=%s\n", msg); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2085 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2086 | /* Obtain userid from userinfo message. */ |
|
19514
9456ceb35a25
Replace msim_parse_body(), which returns a GHashTable * and takes a gchar *,
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19512
diff
changeset
|
2087 | body = msim_msg_get_dictionary(userinfo, "body"); |
|
9456ceb35a25
Replace msim_parse_body(), which returns a GHashTable * and takes a gchar *,
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19512
diff
changeset
|
2088 | g_return_if_fail(body != NULL); |
|
9456ceb35a25
Replace msim_parse_body(), which returns a GHashTable * and takes a gchar *,
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19512
diff
changeset
|
2089 | |
|
9456ceb35a25
Replace msim_parse_body(), which returns a GHashTable * and takes a gchar *,
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19512
diff
changeset
|
2090 | uid = msim_msg_get_integer(body, "UserID"); |
|
9456ceb35a25
Replace msim_parse_body(), which returns a GHashTable * and takes a gchar *,
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19512
diff
changeset
|
2091 | msim_msg_free(body); |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2092 | |
|
19527
039fcd700802
If a username cannot be looked up in postprocessing, throw up an error.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19519
diff
changeset
|
2093 | username = msim_msg_get_string(msg, "_username"); |
|
039fcd700802
If a username cannot be looked up in postprocessing, throw up an error.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19519
diff
changeset
|
2094 | |
|
039fcd700802
If a username cannot be looked up in postprocessing, throw up an error.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19519
diff
changeset
|
2095 | if (!uid) { |
|
039fcd700802
If a username cannot be looked up in postprocessing, throw up an error.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19519
diff
changeset
|
2096 | gchar *msg; |
|
039fcd700802
If a username cannot be looked up in postprocessing, throw up an error.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19519
diff
changeset
|
2097 | |
|
039fcd700802
If a username cannot be looked up in postprocessing, throw up an error.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19519
diff
changeset
|
2098 | msg = g_strdup_printf(_("No such user: %s"), username); |
|
039fcd700802
If a username cannot be looked up in postprocessing, throw up an error.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19519
diff
changeset
|
2099 | purple_notify_error(NULL, NULL, _("User lookup"), msg); |
|
039fcd700802
If a username cannot be looked up in postprocessing, throw up an error.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19519
diff
changeset
|
2100 | g_free(msg); |
|
039fcd700802
If a username cannot be looked up in postprocessing, throw up an error.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19519
diff
changeset
|
2101 | g_free(username); |
|
039fcd700802
If a username cannot be looked up in postprocessing, throw up an error.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19519
diff
changeset
|
2102 | //msim_msg_free(msg); |
|
039fcd700802
If a username cannot be looked up in postprocessing, throw up an error.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19519
diff
changeset
|
2103 | return; |
|
039fcd700802
If a username cannot be looked up in postprocessing, throw up an error.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19519
diff
changeset
|
2104 | } |
|
039fcd700802
If a username cannot be looked up in postprocessing, throw up an error.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19519
diff
changeset
|
2105 | |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2106 | uid_field_name = msim_msg_get_string(msg, "_uid_field_name"); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2107 | uid_before = msim_msg_get_string(msg, "_uid_before"); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2108 | |
|
19514
9456ceb35a25
Replace msim_parse_body(), which returns a GHashTable * and takes a gchar *,
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19512
diff
changeset
|
2109 | msg = msim_do_postprocessing(msg, uid_before, uid_field_name, uid); |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2110 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2111 | /* Send */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2112 | if (!msim_msg_send(session, msg)) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2113 | msim_msg_dump("msim_postprocess_outgoing_cb: sending failed for message: %s\n", msg); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2114 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2115 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2116 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2117 | /* Free field names AFTER sending message, because MsimMessage does NOT copy |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2118 | * field names - instead, treats them as static strings (which they usually are). |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2119 | */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2120 | g_free(uid_field_name); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2121 | g_free(uid_before); |
|
19527
039fcd700802
If a username cannot be looked up in postprocessing, throw up an error.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19519
diff
changeset
|
2122 | g_free(username); |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2123 | //msim_msg_free(msg); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2124 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2125 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2126 | /** Postprocess and send a message. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2127 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2128 | * @param session |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2129 | * @param msg Message to postprocess. Will NOT be freed. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2130 | * @param username Username to resolve. Assumed to be a static string (will not be freed or copied). |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2131 | * @param uid_field_name Name of new field to add, containing uid of username. Static string. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2132 | * @param uid_before Name of existing field to insert username field before. Static string. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2133 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2134 | * @return TRUE if successful. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2135 | */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2136 | gboolean |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2137 | msim_postprocess_outgoing(MsimSession *session, MsimMessage *msg, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2138 | const gchar *username, const gchar *uid_field_name, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2139 | const gchar *uid_before) |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2140 | { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2141 | PurpleBuddy *buddy; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2142 | guint uid; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2143 | gboolean rc; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2144 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2145 | g_return_val_if_fail(msg != NULL, FALSE); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2146 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2147 | /* Store information for msim_postprocess_outgoing_cb(). */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2148 | msim_msg_dump("msim_postprocess_outgoing: msg before=%s\n", msg); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2149 | msg = msim_msg_append(msg, "_username", MSIM_TYPE_STRING, g_strdup(username)); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2150 | msg = msim_msg_append(msg, "_uid_field_name", MSIM_TYPE_STRING, g_strdup(uid_field_name)); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2151 | msg = msim_msg_append(msg, "_uid_before", MSIM_TYPE_STRING, g_strdup(uid_before)); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2152 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2153 | /* First, try the most obvious. If numeric userid is given, use that directly. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2154 | if (msim_is_userid(username)) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2155 | uid = atol(username); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2156 | } else { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2157 | /* Next, see if on buddy list and know uid. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2158 | buddy = purple_find_buddy(session->account, username); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2159 | if (buddy) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2160 | uid = purple_blist_node_get_int(&buddy->node, "UserID"); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2161 | } else { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2162 | uid = 0; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2163 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2164 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2165 | if (!buddy || !uid) |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2166 | { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2167 | /* Don't have uid offhand - need to ask for it, and wait until hear back before sending. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2168 | purple_debug_info("msim", ">>> msim_postprocess_outgoing: couldn't find username %s in blist\n", |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2169 | username ? username : "(NULL)"); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2170 | msim_msg_dump("msim_postprocess_outgoing - scheduling lookup, msg=%s\n", msg); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2171 | /* TODO: where is cloned message freed? Should be in _cb. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2172 | msim_lookup_user(session, username, msim_postprocess_outgoing_cb, msim_msg_clone(msg)); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2173 | return TRUE; /* not sure of status yet - haven't sent! */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2174 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2175 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2176 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2177 | /* Already have uid, postprocess and send msg immediately. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2178 | purple_debug_info("msim", "msim_postprocess_outgoing: found username %s has uid %d\n", |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2179 | username ? username : "(NULL)", uid); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2180 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2181 | msg = msim_do_postprocessing(msg, uid_before, uid_field_name, uid); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2182 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2183 | msim_msg_dump("msim_postprocess_outgoing: msg after (uid immediate)=%s\n", msg); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2184 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2185 | rc = msim_msg_send(session, msg); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2186 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2187 | //msim_msg_free(msg); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2188 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2189 | return rc; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2190 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2191 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2192 | /** Remove a buddy from the user's buddy list. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2193 | void |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2194 | msim_remove_buddy(PurpleConnection *gc, PurpleBuddy *buddy, PurpleGroup *group) |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2195 | { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2196 | MsimSession *session; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2197 | MsimMessage *delbuddy_msg; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2198 | MsimMessage *persist_msg; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2199 | MsimMessage *blocklist_msg; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2200 | GList *blocklist_updates; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2201 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2202 | session = (MsimSession *)gc->proto_data; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2203 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2204 | delbuddy_msg = msim_msg_new( |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2205 | "delbuddy", MSIM_TYPE_BOOLEAN, TRUE, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2206 | "sesskey", MSIM_TYPE_INTEGER, session->sesskey, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2207 | /* 'delprofileid' with uid will be inserted here. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2208 | NULL); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2209 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2210 | if (!msim_postprocess_outgoing(session, delbuddy_msg, buddy->name, "delprofileid", NULL)) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2211 | purple_notify_error(NULL, NULL, _("Failed to remove buddy"), _("'delbuddy' command failed")); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2212 | msim_msg_free(delbuddy_msg); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2213 | return; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2214 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2215 | msim_msg_free(delbuddy_msg); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2216 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2217 | persist_msg = msim_msg_new( |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2218 | "persist", MSIM_TYPE_INTEGER, 1, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2219 | "sesskey", MSIM_TYPE_INTEGER, session->sesskey, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2220 | "cmd", MSIM_TYPE_INTEGER, MSIM_CMD_BIT_ACTION | MSIM_CMD_DELETE, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2221 | "dsn", MSIM_TYPE_INTEGER, MD_DELETE_BUDDY_DSN, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2222 | "lid", MSIM_TYPE_INTEGER, MD_DELETE_BUDDY_LID, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2223 | "uid", MSIM_TYPE_INTEGER, session->userid, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2224 | "rid", MSIM_TYPE_INTEGER, session->next_rid++, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2225 | /* <uid> will be replaced by postprocessing */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2226 | "body", MSIM_TYPE_STRING, g_strdup("ContactID=<uid>"), |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2227 | NULL); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2228 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2229 | if (!msim_postprocess_outgoing(session, persist_msg, buddy->name, "body", NULL)) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2230 | purple_notify_error(NULL, NULL, _("Failed to remove buddy"), _("persist command failed")); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2231 | msim_msg_free(persist_msg); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2232 | return; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2233 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2234 | msim_msg_free(persist_msg); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2235 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2236 | blocklist_updates = NULL; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2237 | blocklist_updates = g_list_prepend(blocklist_updates, "a-"); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2238 | blocklist_updates = g_list_prepend(blocklist_updates, "<uid>"); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2239 | blocklist_updates = g_list_prepend(blocklist_updates, "b-"); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2240 | blocklist_updates = g_list_prepend(blocklist_updates, "<uid>"); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2241 | blocklist_updates = g_list_reverse(blocklist_updates); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2242 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2243 | blocklist_msg = msim_msg_new( |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2244 | "blocklist", MSIM_TYPE_BOOLEAN, TRUE, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2245 | "sesskey", MSIM_TYPE_INTEGER, session->sesskey, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2246 | /* TODO: MsimMessage lists. Currently <uid> isn't replaced in lists. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2247 | //"idlist", MSIM_TYPE_STRING, g_strdup("a-|<uid>|b-|<uid>"), |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2248 | "idlist", MSIM_TYPE_LIST, blocklist_updates, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2249 | NULL); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2250 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2251 | if (!msim_postprocess_outgoing(session, blocklist_msg, buddy->name, "idlist", NULL)) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2252 | purple_notify_error(NULL, NULL, _("Failed to remove buddy"), _("blocklist command failed")); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2253 | msim_msg_free(blocklist_msg); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2254 | return; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2255 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2256 | msim_msg_free(blocklist_msg); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2257 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2258 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2259 | /** Return whether the buddy can be messaged while offline. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2260 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2261 | * The protocol supports offline messages in just the same way as online |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2262 | * messages. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2263 | */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2264 | gboolean |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2265 | msim_offline_message(const PurpleBuddy *buddy) |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2266 | { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2267 | return TRUE; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2268 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2269 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2270 | /** |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2271 | * Callback when input available. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2272 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2273 | * @param gc_uncasted A PurpleConnection pointer. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2274 | * @param source File descriptor. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2275 | * @param cond PURPLE_INPUT_READ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2276 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2277 | * Reads the input, and calls msim_preprocess_incoming() to handle it. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2278 | */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2279 | static void |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2280 | msim_input_cb(gpointer gc_uncasted, gint source, PurpleInputCondition cond) |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2281 | { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2282 | PurpleConnection *gc; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2283 | PurpleAccount *account; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2284 | MsimSession *session; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2285 | gchar *end; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2286 | int n; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2287 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2288 | g_return_if_fail(gc_uncasted != NULL); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2289 | g_return_if_fail(source >= 0); /* Note: 0 is a valid fd */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2290 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2291 | gc = (PurpleConnection *)(gc_uncasted); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2292 | account = purple_connection_get_account(gc); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2293 | session = gc->proto_data; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2294 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2295 | /* libpurple/eventloop.h only defines these two */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2296 | if (cond != PURPLE_INPUT_READ && cond != PURPLE_INPUT_WRITE) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2297 | purple_debug_info("msim_input_cb", "unknown condition=%d\n", cond); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2298 | purple_connection_error(gc, _("Invalid input condition")); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2299 | return; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2300 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2301 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2302 | g_return_if_fail(cond == PURPLE_INPUT_READ); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2303 | g_return_if_fail(MSIM_SESSION_VALID(session)); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2304 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2305 | /* Mark down that we got data, so don't timeout. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2306 | session->last_comm = time(NULL); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2307 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2308 | /* Only can handle so much data at once... |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2309 | * If this happens, try recompiling with a higher MSIM_READ_BUF_SIZE. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2310 | * Should be large enough to hold the largest protocol message. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2311 | */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2312 | if (session->rxoff >= MSIM_READ_BUF_SIZE) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2313 | purple_debug_error("msim", |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2314 | "msim_input_cb: %d-byte read buffer full! rxoff=%d\n", |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2315 | MSIM_READ_BUF_SIZE, session->rxoff); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2316 | purple_connection_error(gc, _("Read buffer full")); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2317 | return; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2318 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2319 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2320 | purple_debug_info("msim", "buffer at %d (max %d), reading up to %d\n", |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2321 | session->rxoff, MSIM_READ_BUF_SIZE, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2322 | MSIM_READ_BUF_SIZE - session->rxoff); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2323 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2324 | /* Read into buffer. On Win32, need recv() not read(). session->fd also holds |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2325 | * the file descriptor, but it sometimes differs from the 'source' parameter. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2326 | */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2327 | n = recv(session->fd, session->rxbuf + session->rxoff, MSIM_READ_BUF_SIZE - session->rxoff, 0); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2328 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2329 | if (n < 0 && errno == EAGAIN) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2330 | return; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2331 | } else if (n < 0) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2332 | purple_debug_error("msim", "msim_input_cb: read error, ret=%d, " |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2333 | "error=%s, source=%d, fd=%d (%X))\n", |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2334 | n, strerror(errno), source, session->fd, session->fd); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2335 | purple_connection_error(gc, _("Read error")); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2336 | return; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2337 | } else if (n == 0) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2338 | purple_debug_info("msim", "msim_input_cb: server disconnected\n"); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2339 | purple_connection_error(gc, _("Server has disconnected")); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2340 | return; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2341 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2342 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2343 | if (n + session->rxoff >= MSIM_READ_BUF_SIZE) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2344 | purple_debug_info("msim_input_cb", "received %d bytes, pushing rxoff to %d, over buffer size of %d\n", |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2345 | n, n + session->rxoff, MSIM_READ_BUF_SIZE); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2346 | /* TODO: g_realloc like msn, yahoo, irc, jabber? */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2347 | purple_connection_error(gc, _("Read buffer full")); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2348 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2349 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2350 | /* Null terminate */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2351 | purple_debug_info("msim", "msim_input_cb: going to null terminate " |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2352 | "at n=%d\n", n); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2353 | session->rxbuf[session->rxoff + n] = 0; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2354 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2355 | #ifdef MSIM_CHECK_EMBEDDED_NULLS |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2356 | /* Check for embedded NULs. I don't handle them, and they shouldn't occur. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2357 | if (strlen(session->rxbuf + session->rxoff) != n) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2358 | /* Occurs after login, but it is not a null byte. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2359 | purple_debug_info("msim", "msim_input_cb: strlen=%d, but read %d bytes" |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2360 | "--null byte encountered?\n", |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2361 | strlen(session->rxbuf + session->rxoff), n); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2362 | //purple_connection_error(gc, "Invalid message - null byte on input"); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2363 | return; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2364 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2365 | #endif |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2366 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2367 | session->rxoff += n; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2368 | purple_debug_info("msim", "msim_input_cb: read=%d\n", n); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2369 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2370 | #ifdef MSIM_DEBUG_RXBUF |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2371 | purple_debug_info("msim", "buf=<%s>\n", session->rxbuf); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2372 | #endif |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2373 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2374 | /* Look for \\final\\ end markers. If found, process message. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2375 | while((end = strstr(session->rxbuf, MSIM_FINAL_STRING))) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2376 | MsimMessage *msg; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2377 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2378 | #ifdef MSIM_DEBUG_RXBUF |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2379 | purple_debug_info("msim", "in loop: buf=<%s>\n", session->rxbuf); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2380 | #endif |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2381 | *end = 0; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2382 | msg = msim_parse(g_strdup(session->rxbuf)); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2383 | if (!msg) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2384 | purple_debug_info("msim", "msim_input_cb: couldn't parse rxbuf\n"); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2385 | purple_connection_error(gc, _("Unparseable message")); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2386 | } else { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2387 | /* Process message and then free it (processing function should |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2388 | * clone message if it wants to keep it afterwards.) */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2389 | if (!msim_preprocess_incoming(session, msg)) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2390 | msim_msg_dump("msim_input_cb: preprocessing message failed on msg: %s\n", msg); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2391 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2392 | msim_msg_free(msg); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2393 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2394 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2395 | /* Move remaining part of buffer to beginning. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2396 | session->rxoff -= strlen(session->rxbuf) + strlen(MSIM_FINAL_STRING); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2397 | memmove(session->rxbuf, end + strlen(MSIM_FINAL_STRING), |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2398 | MSIM_READ_BUF_SIZE - (end + strlen(MSIM_FINAL_STRING) - session->rxbuf)); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2399 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2400 | /* Clear end of buffer */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2401 | //memset(end, 0, MSIM_READ_BUF_SIZE - (end - session->rxbuf)); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2402 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2403 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2404 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2405 | /* Setup a callback, to be called when a reply is received with the returned rid. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2406 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2407 | * @param cb The callback, an MSIM_USER_LOOKUP_CB. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2408 | * @param data Arbitrary user data to be passed to callback (probably an MsimMessage *). |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2409 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2410 | * @return The request/reply ID, used to link replies with requests, or -1. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2411 | * Put the rid in your request, 'rid' field. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2412 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2413 | * TODO: Make more generic and more specific: |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2414 | * 1) MSIM_USER_LOOKUP_CB - make it for PERSIST_REPLY, not just user lookup |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2415 | * 2) data - make it an MsimMessage? |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2416 | */ |
|
19619
e9ac2df3fd1b
In msimprpl, move user-related code to a new user module, and move other
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19618
diff
changeset
|
2417 | guint |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2418 | msim_new_reply_callback(MsimSession *session, MSIM_USER_LOOKUP_CB cb, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2419 | gpointer data) |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2420 | { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2421 | guint rid; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2422 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2423 | g_return_val_if_fail(MSIM_SESSION_VALID(session), -1); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2424 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2425 | rid = session->next_rid++; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2426 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2427 | g_hash_table_insert(session->user_lookup_cb, GUINT_TO_POINTER(rid), cb); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2428 | g_hash_table_insert(session->user_lookup_cb_data, GUINT_TO_POINTER(rid), data); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2429 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2430 | return rid; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2431 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2432 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2433 | /** |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2434 | * Callback when connected. Sets up input handlers. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2435 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2436 | * @param data A PurpleConnection pointer. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2437 | * @param source File descriptor. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2438 | * @param error_message |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2439 | */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2440 | static void |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2441 | msim_connect_cb(gpointer data, gint source, const gchar *error_message) |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2442 | { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2443 | PurpleConnection *gc; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2444 | MsimSession *session; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2445 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2446 | g_return_if_fail(data != NULL); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2447 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2448 | gc = (PurpleConnection *)data; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2449 | session = (MsimSession *)gc->proto_data; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2450 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2451 | if (source < 0) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2452 | purple_connection_error(gc, _("Couldn't connect to host")); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2453 | purple_connection_error(gc, g_strdup_printf( |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2454 | _("Couldn't connect to host: %s (%d)"), |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2455 | error_message ? error_message : "no message given", |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2456 | source)); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2457 | return; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2458 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2459 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2460 | session->fd = source; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2461 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2462 | gc->inpa = purple_input_add(source, PURPLE_INPUT_READ, msim_input_cb, gc); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2463 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2464 | |
|
19617
c2da44d56312
In msimprpl, move session-related functions to a new session module.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19616
diff
changeset
|
2465 | |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2466 | /** |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2467 | * Close the connection. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2468 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2469 | * @param gc The connection. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2470 | */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2471 | void |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2472 | msim_close(PurpleConnection *gc) |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2473 | { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2474 | MsimSession *session; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2475 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2476 | if (gc == NULL) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2477 | return; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2478 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2479 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2480 | session = (MsimSession *)gc->proto_data; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2481 | if (session == NULL) |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2482 | return; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2483 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2484 | gc->proto_data = NULL; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2485 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2486 | if (!MSIM_SESSION_VALID(session)) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2487 | return; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2488 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2489 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2490 | if (session->gc->inpa) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2491 | purple_input_remove(session->gc->inpa); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2492 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2493 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2494 | msim_session_destroy(session); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2495 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2496 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2497 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2498 | /** |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2499 | * Obtain the status text for a buddy. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2500 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2501 | * @param buddy The buddy to obtain status text for. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2502 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2503 | * @return Status text, or NULL if error. Caller g_free()'s. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2504 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2505 | */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2506 | char * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2507 | msim_status_text(PurpleBuddy *buddy) |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2508 | { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2509 | MsimSession *session; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2510 | MsimUser *user; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2511 | const gchar *display_name, *headline; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2512 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2513 | g_return_val_if_fail(buddy != NULL, NULL); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2514 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2515 | user = msim_get_user_from_buddy(buddy); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2516 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2517 | session = (MsimSession *)buddy->account->gc->proto_data; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2518 | g_return_val_if_fail(MSIM_SESSION_VALID(session), NULL); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2519 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2520 | display_name = headline = NULL; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2521 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2522 | /* Retrieve display name and/or headline, depending on user preference. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2523 | if (purple_account_get_bool(session->account, "show_display_name", TRUE)) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2524 | display_name = user->display_name; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2525 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2526 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2527 | if (purple_account_get_bool(session->account, "show_headline", FALSE)) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2528 | headline = user->headline; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2529 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2530 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2531 | /* Return appropriate combination of display name and/or headline, or neither. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2532 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2533 | if (display_name && headline) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2534 | return g_strconcat(display_name, " ", headline, NULL); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2535 | } else if (display_name) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2536 | return g_strdup(display_name); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2537 | } else if (headline) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2538 | return g_strdup(headline); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2539 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2540 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2541 | return NULL; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2542 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2543 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2544 | /** |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2545 | * Obtain the tooltip text for a buddy. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2546 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2547 | * @param buddy Buddy to obtain tooltip text on. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2548 | * @param user_info Variable modified to have the tooltip text. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2549 | * @param full TRUE if should obtain full tooltip text. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2550 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2551 | */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2552 | void |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2553 | msim_tooltip_text(PurpleBuddy *buddy, PurpleNotifyUserInfo *user_info, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2554 | gboolean full) |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2555 | { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2556 | MsimUser *user; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2557 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2558 | g_return_if_fail(buddy != NULL); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2559 | g_return_if_fail(user_info != NULL); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2560 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2561 | user = msim_get_user_from_buddy(buddy); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2562 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2563 | if (PURPLE_BUDDY_IS_ONLINE(buddy)) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2564 | MsimSession *session; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2565 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2566 | session = (MsimSession *)buddy->account->gc->proto_data; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2567 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2568 | g_return_if_fail(MSIM_SESSION_VALID(session)); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2569 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2570 | /* TODO: if (full), do something different? */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2571 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2572 | /* TODO: request information? have to figure out how to do |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2573 | * the asynchronous lookup like oscar does (tooltip shows |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2574 | * 'retrieving...' if not yet available, then changes when it is). |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2575 | * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2576 | * Right now, only show what we have on hand. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2577 | */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2578 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2579 | /* Show abbreviated user info. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2580 | msim_append_user_info(session, user_info, user, FALSE); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2581 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2582 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2583 | |
|
19518
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2584 | /** Add contact from server to buddy list, after looking up username. |
|
19519
e4049e92eb22
Fix crashes. In myspace.c, clone the contact_info message before sending it to
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19518
diff
changeset
|
2585 | * Callback from msim_add_contact_from_server(). |
|
e4049e92eb22
Fix crashes. In myspace.c, clone the contact_info message before sending it to
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19518
diff
changeset
|
2586 | * |
|
e4049e92eb22
Fix crashes. In myspace.c, clone the contact_info message before sending it to
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19518
diff
changeset
|
2587 | * @param data An MsimMessage * of the contact information. Will be freed. |
|
e4049e92eb22
Fix crashes. In myspace.c, clone the contact_info message before sending it to
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19518
diff
changeset
|
2588 | */ |
|
19518
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2589 | static void |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2590 | msim_add_contact_from_server_cb(MsimSession *session, MsimMessage *user_lookup_info, gpointer data) |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2591 | { |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2592 | MsimMessage *contact_info, *user_lookup_info_body; |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2593 | PurpleGroup *group; |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2594 | PurpleBuddy *buddy; |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2595 | MsimUser *user; |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2596 | gchar *username, *group_name; |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2597 | guint uid; |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2598 | |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2599 | contact_info = (MsimMessage *)data; |
|
19519
e4049e92eb22
Fix crashes. In myspace.c, clone the contact_info message before sending it to
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19518
diff
changeset
|
2600 | purple_debug_info("msim_add_contact_from_server_cb", "contact_info addr=%X\n", contact_info); |
|
19518
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2601 | uid = msim_msg_get_integer(contact_info, "ContactID"); |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2602 | |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2603 | if (!user_lookup_info) { |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2604 | username = g_strdup(msim_uid2username_from_blist(session, uid)); |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2605 | g_return_if_fail(username != NULL); |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2606 | } else { |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2607 | user_lookup_info_body = msim_msg_get_dictionary(user_lookup_info, "body"); |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2608 | username = msim_msg_get_string(user_lookup_info_body, "UserName"); |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2609 | msim_msg_free(user_lookup_info_body); |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2610 | g_return_if_fail(username != NULL); |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2611 | } |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2612 | |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2613 | purple_debug_info("msim_add_contact_from_server_cb", |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2614 | "*** about to add/update username=%s\n", username); |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2615 | |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2616 | /* 1. Creates a new group, or gets existing group if it exists (or so |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2617 | * the documentation claims). */ |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2618 | group_name = msim_msg_get_string(contact_info, "GroupName"); |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2619 | if (group_name) { |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2620 | group = purple_group_new(group_name); |
|
19531
799c0e65f51f
Improve buddy importing. Count number of buddies being added, and
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19530
diff
changeset
|
2621 | purple_debug_info("msim_add_contact_from_server_cb", |
|
799c0e65f51f
Improve buddy importing. Count number of buddies being added, and
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19530
diff
changeset
|
2622 | "adding to GroupName: %s\n", group_name); |
|
19518
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2623 | g_free(group_name); |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2624 | } else { |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2625 | group = purple_group_new(_("IM Friends")); |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2626 | } |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2627 | |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2628 | /* 2. Get or create buddy */ |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2629 | buddy = purple_find_buddy(session->account, username); |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2630 | if (!buddy) { |
|
19531
799c0e65f51f
Improve buddy importing. Count number of buddies being added, and
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19530
diff
changeset
|
2631 | purple_debug_info("msim_add_contact_from_server_cb", |
|
799c0e65f51f
Improve buddy importing. Count number of buddies being added, and
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19530
diff
changeset
|
2632 | "creating new buddy: %s\n", username); |
|
19518
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2633 | buddy = purple_buddy_new(session->account, username, NULL); |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2634 | } |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2635 | |
|
19531
799c0e65f51f
Improve buddy importing. Count number of buddies being added, and
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19530
diff
changeset
|
2636 | /* Add group to beginning. See #2752. */ |
|
799c0e65f51f
Improve buddy importing. Count number of buddies being added, and
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19530
diff
changeset
|
2637 | purple_blist_add_group(group, NULL); |
|
799c0e65f51f
Improve buddy importing. Count number of buddies being added, and
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19530
diff
changeset
|
2638 | |
|
19518
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2639 | /* TODO: use 'Position' in contact_info to take into account where buddy is */ |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2640 | purple_blist_add_buddy(buddy, NULL, group, NULL /* insertion point */); |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2641 | |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2642 | /* 3. Update buddy information */ |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2643 | user = msim_get_user_from_buddy(buddy); |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2644 | |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2645 | /* All buddies on list should have 'uid' integer associated with them. */ |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2646 | purple_blist_node_set_int(&buddy->node, "UserID", uid); |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2647 | |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2648 | /* Stores a few fields in the MsimUser, relevant to the buddy itself. |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2649 | * AvatarURL, Headline, ContactID. */ |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2650 | msim_store_user_info(session, contact_info, NULL); |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2651 | |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2652 | /* TODO: other fields, store in 'user' */ |
|
19519
e4049e92eb22
Fix crashes. In myspace.c, clone the contact_info message before sending it to
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19518
diff
changeset
|
2653 | |
|
e4049e92eb22
Fix crashes. In myspace.c, clone the contact_info message before sending it to
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19518
diff
changeset
|
2654 | msim_msg_free(contact_info); |
|
19518
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2655 | } |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2656 | |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2657 | /** Add first ContactID in contact_info to buddy's list. Used to add |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2658 | * server-side buddies to client-side list. |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2659 | * |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2660 | * @return TRUE if added. |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2661 | * */ |
|
19531
799c0e65f51f
Improve buddy importing. Count number of buddies being added, and
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19530
diff
changeset
|
2662 | static gboolean |
|
19518
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2663 | msim_add_contact_from_server(MsimSession *session, MsimMessage *contact_info) |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2664 | { |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2665 | guint uid; |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2666 | const gchar *username; |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2667 | |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2668 | uid = msim_msg_get_integer(contact_info, "ContactID"); |
|
19531
799c0e65f51f
Improve buddy importing. Count number of buddies being added, and
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19530
diff
changeset
|
2669 | g_return_val_if_fail(uid != 0, FALSE); |
|
19518
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2670 | |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2671 | /* Lookup the username, since NickName and IMName is unreliable */ |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2672 | username = msim_uid2username_from_blist(session, uid); |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2673 | if (!username) { |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2674 | gchar *uid_str; |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2675 | |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2676 | uid_str = g_strdup_printf("%d", uid); |
|
19519
e4049e92eb22
Fix crashes. In myspace.c, clone the contact_info message before sending it to
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19518
diff
changeset
|
2677 | purple_debug_info("msim_add_contact_from_server", |
|
e4049e92eb22
Fix crashes. In myspace.c, clone the contact_info message before sending it to
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19518
diff
changeset
|
2678 | "contact_info addr=%X\n", contact_info); |
|
e4049e92eb22
Fix crashes. In myspace.c, clone the contact_info message before sending it to
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19518
diff
changeset
|
2679 | msim_lookup_user(session, uid_str, msim_add_contact_from_server_cb, (gpointer)msim_msg_clone(contact_info)); |
|
19518
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2680 | g_free(uid_str); |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2681 | } else { |
|
19519
e4049e92eb22
Fix crashes. In myspace.c, clone the contact_info message before sending it to
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19518
diff
changeset
|
2682 | msim_add_contact_from_server_cb(session, NULL, (gpointer)msim_msg_clone(contact_info)); |
|
19518
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2683 | } |
|
19531
799c0e65f51f
Improve buddy importing. Count number of buddies being added, and
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19530
diff
changeset
|
2684 | |
|
799c0e65f51f
Improve buddy importing. Count number of buddies being added, and
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19530
diff
changeset
|
2685 | /* Say that the contact was added, even if we're still looking up |
|
799c0e65f51f
Improve buddy importing. Count number of buddies being added, and
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19530
diff
changeset
|
2686 | * their username. */ |
|
799c0e65f51f
Improve buddy importing. Count number of buddies being added, and
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19530
diff
changeset
|
2687 | return TRUE; |
|
19518
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2688 | } |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2689 | |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2690 | /** Called when contact list is received from server. */ |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2691 | static void |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2692 | msim_got_contact_list(MsimSession *session, MsimMessage *reply, gpointer user_data) |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2693 | { |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2694 | MsimMessage *body, *body_node; |
|
19531
799c0e65f51f
Improve buddy importing. Count number of buddies being added, and
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19530
diff
changeset
|
2695 | gchar *msg; |
|
799c0e65f51f
Improve buddy importing. Count number of buddies being added, and
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19530
diff
changeset
|
2696 | guint buddy_count; |
|
19518
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2697 | |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2698 | msim_msg_dump("msim_got_contact_list: reply=%s", reply); |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2699 | |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2700 | body = msim_msg_get_dictionary(reply, "body"); |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2701 | g_return_if_fail(body != NULL); |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2702 | |
|
19531
799c0e65f51f
Improve buddy importing. Count number of buddies being added, and
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19530
diff
changeset
|
2703 | buddy_count = 0; |
|
799c0e65f51f
Improve buddy importing. Count number of buddies being added, and
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19530
diff
changeset
|
2704 | |
|
19518
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2705 | for (body_node = body; |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2706 | body_node != NULL; |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2707 | body_node = msim_msg_get_next_element_node(body_node)) |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2708 | { |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2709 | MsimMessageElement *elem; |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2710 | |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2711 | elem = (MsimMessageElement *)body_node->data; |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2712 | |
|
19606
afc90bd82e6d
In msimprpl, replace !strcmp() with g_str_equal() everywhere.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19605
diff
changeset
|
2713 | if (g_str_equal(elem->name, "ContactID")) |
|
19518
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2714 | { |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2715 | /* Will look for first contact in body_node */ |
|
19531
799c0e65f51f
Improve buddy importing. Count number of buddies being added, and
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19530
diff
changeset
|
2716 | if (msim_add_contact_from_server(session, body_node)) { |
|
799c0e65f51f
Improve buddy importing. Count number of buddies being added, and
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19530
diff
changeset
|
2717 | ++buddy_count; |
|
799c0e65f51f
Improve buddy importing. Count number of buddies being added, and
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19530
diff
changeset
|
2718 | } |
|
19518
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2719 | } |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2720 | } |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2721 | |
|
19640
48e64a5069da
On login, get contacts from server using msim_get_contact_list().
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19634
diff
changeset
|
2722 | switch (GPOINTER_TO_UINT(user_data)) { |
|
48e64a5069da
On login, get contacts from server using msim_get_contact_list().
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19634
diff
changeset
|
2723 | case MSIM_CONTACT_LIST_IMPORT_ALL_FRIENDS: |
|
19737
6e363a9b0699
Clarify message about contacts added from server, for #2918.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19731
diff
changeset
|
2724 | msg = g_strdup_printf(_("%d buddies were added or updated from the server (including buddies already on the server-side list)"), buddy_count); |
|
19640
48e64a5069da
On login, get contacts from server using msim_get_contact_list().
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19634
diff
changeset
|
2725 | purple_notify_info(session->account, _("Add contacts from server"), msg, NULL); |
|
48e64a5069da
On login, get contacts from server using msim_get_contact_list().
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19634
diff
changeset
|
2726 | g_free(msg); |
|
48e64a5069da
On login, get contacts from server using msim_get_contact_list().
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19634
diff
changeset
|
2727 | break; |
|
48e64a5069da
On login, get contacts from server using msim_get_contact_list().
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19634
diff
changeset
|
2728 | |
|
48e64a5069da
On login, get contacts from server using msim_get_contact_list().
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19634
diff
changeset
|
2729 | case MSIM_CONTACT_LIST_IMPORT_TOP_FRIENDS: |
|
48e64a5069da
On login, get contacts from server using msim_get_contact_list().
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19634
diff
changeset
|
2730 | /* TODO */ |
|
48e64a5069da
On login, get contacts from server using msim_get_contact_list().
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19634
diff
changeset
|
2731 | break; |
|
48e64a5069da
On login, get contacts from server using msim_get_contact_list().
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19634
diff
changeset
|
2732 | |
|
48e64a5069da
On login, get contacts from server using msim_get_contact_list().
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19634
diff
changeset
|
2733 | case MSIM_CONTACT_LIST_INITIAL_FRIENDS: |
|
48e64a5069da
On login, get contacts from server using msim_get_contact_list().
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19634
diff
changeset
|
2734 | /* Nothing */ |
|
48e64a5069da
On login, get contacts from server using msim_get_contact_list().
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19634
diff
changeset
|
2735 | break; |
|
48e64a5069da
On login, get contacts from server using msim_get_contact_list().
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19634
diff
changeset
|
2736 | } |
|
19531
799c0e65f51f
Improve buddy importing. Count number of buddies being added, and
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19530
diff
changeset
|
2737 | |
|
19518
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2738 | msim_msg_free(body); |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2739 | } |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2740 | |
|
19640
48e64a5069da
On login, get contacts from server using msim_get_contact_list().
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19634
diff
changeset
|
2741 | /* Get contact list, calling msim_got_contact_list() with what_to_do_after as user_data gpointer. */ |
|
48e64a5069da
On login, get contacts from server using msim_get_contact_list().
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19634
diff
changeset
|
2742 | static gboolean |
|
48e64a5069da
On login, get contacts from server using msim_get_contact_list().
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19634
diff
changeset
|
2743 | msim_get_contact_list(MsimSession *session, int what_to_do_after) |
|
48e64a5069da
On login, get contacts from server using msim_get_contact_list().
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19634
diff
changeset
|
2744 | { |
|
48e64a5069da
On login, get contacts from server using msim_get_contact_list().
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19634
diff
changeset
|
2745 | return msim_send(session, |
|
48e64a5069da
On login, get contacts from server using msim_get_contact_list().
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19634
diff
changeset
|
2746 | "persist", MSIM_TYPE_INTEGER, 1, |
|
48e64a5069da
On login, get contacts from server using msim_get_contact_list().
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19634
diff
changeset
|
2747 | "sesskey", MSIM_TYPE_INTEGER, session->sesskey, |
|
48e64a5069da
On login, get contacts from server using msim_get_contact_list().
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19634
diff
changeset
|
2748 | "cmd", MSIM_TYPE_INTEGER, MSIM_CMD_GET, |
|
48e64a5069da
On login, get contacts from server using msim_get_contact_list().
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19634
diff
changeset
|
2749 | "dsn", MSIM_TYPE_INTEGER, MG_LIST_ALL_CONTACTS_DSN, |
|
48e64a5069da
On login, get contacts from server using msim_get_contact_list().
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19634
diff
changeset
|
2750 | "lid", MSIM_TYPE_INTEGER, MG_LIST_ALL_CONTACTS_LID, |
|
48e64a5069da
On login, get contacts from server using msim_get_contact_list().
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19634
diff
changeset
|
2751 | "uid", MSIM_TYPE_INTEGER, session->userid, |
|
48e64a5069da
On login, get contacts from server using msim_get_contact_list().
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19634
diff
changeset
|
2752 | "rid", MSIM_TYPE_INTEGER, |
|
48e64a5069da
On login, get contacts from server using msim_get_contact_list().
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19634
diff
changeset
|
2753 | msim_new_reply_callback(session, msim_got_contact_list, GUINT_TO_POINTER(what_to_do_after)), |
|
48e64a5069da
On login, get contacts from server using msim_get_contact_list().
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19634
diff
changeset
|
2754 | "body", MSIM_TYPE_STRING, g_strdup(""), |
|
48e64a5069da
On login, get contacts from server using msim_get_contact_list().
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19634
diff
changeset
|
2755 | NULL); |
|
48e64a5069da
On login, get contacts from server using msim_get_contact_list().
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19634
diff
changeset
|
2756 | } |
|
48e64a5069da
On login, get contacts from server using msim_get_contact_list().
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19634
diff
changeset
|
2757 | |
|
48e64a5069da
On login, get contacts from server using msim_get_contact_list().
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19634
diff
changeset
|
2758 | |
|
19518
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2759 | /** Called when friends have been imported to buddy list on server. */ |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2760 | static void |
|
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2761 | msim_import_friends_cb(MsimSession *session, MsimMessage *reply, gpointer user_data) |
|
19512
040a04d43bbb
First half of "Add friends from MySpace.com" support: add msim_import_friends(),
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19510
diff
changeset
|
2762 | { |
|
040a04d43bbb
First half of "Add friends from MySpace.com" support: add msim_import_friends(),
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19510
diff
changeset
|
2763 | MsimMessage *body; |
|
040a04d43bbb
First half of "Add friends from MySpace.com" support: add msim_import_friends(),
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19510
diff
changeset
|
2764 | gchar *completed; |
|
040a04d43bbb
First half of "Add friends from MySpace.com" support: add msim_import_friends(),
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19510
diff
changeset
|
2765 | msim_msg_dump("msim_import_friends_cb=%s", reply); |
|
040a04d43bbb
First half of "Add friends from MySpace.com" support: add msim_import_friends(),
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19510
diff
changeset
|
2766 | |
|
040a04d43bbb
First half of "Add friends from MySpace.com" support: add msim_import_friends(),
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19510
diff
changeset
|
2767 | /* Check if the friends were imported successfully. */ |
|
040a04d43bbb
First half of "Add friends from MySpace.com" support: add msim_import_friends(),
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19510
diff
changeset
|
2768 | body = msim_msg_get_dictionary(reply, "body"); |
|
040a04d43bbb
First half of "Add friends from MySpace.com" support: add msim_import_friends(),
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19510
diff
changeset
|
2769 | g_return_if_fail(body != NULL); |
|
040a04d43bbb
First half of "Add friends from MySpace.com" support: add msim_import_friends(),
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19510
diff
changeset
|
2770 | completed = msim_msg_get_string(body, "Completed"); |
|
040a04d43bbb
First half of "Add friends from MySpace.com" support: add msim_import_friends(),
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19510
diff
changeset
|
2771 | g_return_if_fail(body != NULL); |
|
040a04d43bbb
First half of "Add friends from MySpace.com" support: add msim_import_friends(),
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19510
diff
changeset
|
2772 | msim_msg_free(body); |
|
19606
afc90bd82e6d
In msimprpl, replace !strcmp() with g_str_equal() everywhere.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19605
diff
changeset
|
2773 | if (!g_str_equal(completed, "True")) |
|
19512
040a04d43bbb
First half of "Add friends from MySpace.com" support: add msim_import_friends(),
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19510
diff
changeset
|
2774 | { |
|
040a04d43bbb
First half of "Add friends from MySpace.com" support: add msim_import_friends(),
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19510
diff
changeset
|
2775 | purple_debug_info("msim_import_friends_cb", |
|
040a04d43bbb
First half of "Add friends from MySpace.com" support: add msim_import_friends(),
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19510
diff
changeset
|
2776 | "failed to import friends: %s", completed); |
|
040a04d43bbb
First half of "Add friends from MySpace.com" support: add msim_import_friends(),
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19510
diff
changeset
|
2777 | purple_notify_error(session->account, _("Add friends from MySpace.com"), |
|
040a04d43bbb
First half of "Add friends from MySpace.com" support: add msim_import_friends(),
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19510
diff
changeset
|
2778 | _("Importing friends failed"), NULL); |
|
040a04d43bbb
First half of "Add friends from MySpace.com" support: add msim_import_friends(),
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19510
diff
changeset
|
2779 | g_free(completed); |
|
040a04d43bbb
First half of "Add friends from MySpace.com" support: add msim_import_friends(),
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19510
diff
changeset
|
2780 | return; |
|
040a04d43bbb
First half of "Add friends from MySpace.com" support: add msim_import_friends(),
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19510
diff
changeset
|
2781 | } |
|
040a04d43bbb
First half of "Add friends from MySpace.com" support: add msim_import_friends(),
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19510
diff
changeset
|
2782 | g_free(completed); |
|
040a04d43bbb
First half of "Add friends from MySpace.com" support: add msim_import_friends(),
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19510
diff
changeset
|
2783 | |
|
040a04d43bbb
First half of "Add friends from MySpace.com" support: add msim_import_friends(),
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19510
diff
changeset
|
2784 | purple_debug_info("msim_import_friends_cb", |
|
19518
5b592bad565a
Initial implementation of friend importing. Not well tested.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19514
diff
changeset
|
2785 | "added friends to server-side buddy list, requesting new contacts from server"); |
|
19512
040a04d43bbb
First half of "Add friends from MySpace.com" support: add msim_import_friends(),
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19510
diff
changeset
|
2786 | |
|
19640
48e64a5069da
On login, get contacts from server using msim_get_contact_list().
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19634
diff
changeset
|
2787 | msim_get_contact_list(session, MSIM_CONTACT_LIST_IMPORT_ALL_FRIENDS); |
|
19512
040a04d43bbb
First half of "Add friends from MySpace.com" support: add msim_import_friends(),
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19510
diff
changeset
|
2788 | |
|
040a04d43bbb
First half of "Add friends from MySpace.com" support: add msim_import_friends(),
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19510
diff
changeset
|
2789 | /* TODO: show, X friends have been added */ |
|
040a04d43bbb
First half of "Add friends from MySpace.com" support: add msim_import_friends(),
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19510
diff
changeset
|
2790 | } |
|
040a04d43bbb
First half of "Add friends from MySpace.com" support: add msim_import_friends(),
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19510
diff
changeset
|
2791 | |
|
040a04d43bbb
First half of "Add friends from MySpace.com" support: add msim_import_friends(),
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19510
diff
changeset
|
2792 | /** Import friends from myspace.com. */ |
|
040a04d43bbb
First half of "Add friends from MySpace.com" support: add msim_import_friends(),
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19510
diff
changeset
|
2793 | static void msim_import_friends(PurplePluginAction *action) |
|
040a04d43bbb
First half of "Add friends from MySpace.com" support: add msim_import_friends(),
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19510
diff
changeset
|
2794 | { |
|
040a04d43bbb
First half of "Add friends from MySpace.com" support: add msim_import_friends(),
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19510
diff
changeset
|
2795 | PurpleConnection *gc; |
|
040a04d43bbb
First half of "Add friends from MySpace.com" support: add msim_import_friends(),
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19510
diff
changeset
|
2796 | MsimSession *session; |
|
040a04d43bbb
First half of "Add friends from MySpace.com" support: add msim_import_friends(),
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19510
diff
changeset
|
2797 | gchar *group_name; |
|
040a04d43bbb
First half of "Add friends from MySpace.com" support: add msim_import_friends(),
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19510
diff
changeset
|
2798 | |
|
040a04d43bbb
First half of "Add friends from MySpace.com" support: add msim_import_friends(),
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19510
diff
changeset
|
2799 | gc = (PurpleConnection *)action->context; |
|
040a04d43bbb
First half of "Add friends from MySpace.com" support: add msim_import_friends(),
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19510
diff
changeset
|
2800 | session = (MsimSession *)gc->proto_data; |
|
040a04d43bbb
First half of "Add friends from MySpace.com" support: add msim_import_friends(),
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19510
diff
changeset
|
2801 | |
|
040a04d43bbb
First half of "Add friends from MySpace.com" support: add msim_import_friends(),
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19510
diff
changeset
|
2802 | group_name = "MySpace Friends"; |
|
040a04d43bbb
First half of "Add friends from MySpace.com" support: add msim_import_friends(),
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19510
diff
changeset
|
2803 | |
|
040a04d43bbb
First half of "Add friends from MySpace.com" support: add msim_import_friends(),
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19510
diff
changeset
|
2804 | g_return_if_fail(msim_send(session, |
|
040a04d43bbb
First half of "Add friends from MySpace.com" support: add msim_import_friends(),
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19510
diff
changeset
|
2805 | "persist", MSIM_TYPE_INTEGER, 1, |
|
040a04d43bbb
First half of "Add friends from MySpace.com" support: add msim_import_friends(),
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19510
diff
changeset
|
2806 | "sesskey", MSIM_TYPE_INTEGER, session->sesskey, |
|
040a04d43bbb
First half of "Add friends from MySpace.com" support: add msim_import_friends(),
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19510
diff
changeset
|
2807 | "cmd", MSIM_TYPE_INTEGER, MSIM_CMD_PUT, |
|
040a04d43bbb
First half of "Add friends from MySpace.com" support: add msim_import_friends(),
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19510
diff
changeset
|
2808 | "dsn", MSIM_TYPE_INTEGER, MC_IMPORT_ALL_FRIENDS_DSN, |
|
040a04d43bbb
First half of "Add friends from MySpace.com" support: add msim_import_friends(),
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19510
diff
changeset
|
2809 | "lid", MSIM_TYPE_INTEGER, MC_IMPORT_ALL_FRIENDS_LID, |
|
040a04d43bbb
First half of "Add friends from MySpace.com" support: add msim_import_friends(),
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19510
diff
changeset
|
2810 | "uid", MSIM_TYPE_INTEGER, session->userid, |
|
040a04d43bbb
First half of "Add friends from MySpace.com" support: add msim_import_friends(),
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19510
diff
changeset
|
2811 | "rid", MSIM_TYPE_INTEGER, |
|
040a04d43bbb
First half of "Add friends from MySpace.com" support: add msim_import_friends(),
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19510
diff
changeset
|
2812 | msim_new_reply_callback(session, msim_import_friends_cb, NULL), |
|
040a04d43bbb
First half of "Add friends from MySpace.com" support: add msim_import_friends(),
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19510
diff
changeset
|
2813 | "body", MSIM_TYPE_STRING, |
|
040a04d43bbb
First half of "Add friends from MySpace.com" support: add msim_import_friends(),
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19510
diff
changeset
|
2814 | g_strdup_printf("GroupName=%s", group_name), |
|
040a04d43bbb
First half of "Add friends from MySpace.com" support: add msim_import_friends(),
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19510
diff
changeset
|
2815 | NULL)); |
|
040a04d43bbb
First half of "Add friends from MySpace.com" support: add msim_import_friends(),
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19510
diff
changeset
|
2816 | |
|
040a04d43bbb
First half of "Add friends from MySpace.com" support: add msim_import_friends(),
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19510
diff
changeset
|
2817 | |
|
040a04d43bbb
First half of "Add friends from MySpace.com" support: add msim_import_friends(),
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19510
diff
changeset
|
2818 | } |
|
040a04d43bbb
First half of "Add friends from MySpace.com" support: add msim_import_friends(),
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19510
diff
changeset
|
2819 | |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2820 | /** Actions menu for account. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2821 | GList * |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2822 | msim_actions(PurplePlugin *plugin, gpointer context) |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2823 | { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2824 | PurpleConnection *gc; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2825 | GList *menu; |
|
19512
040a04d43bbb
First half of "Add friends from MySpace.com" support: add msim_import_friends(),
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19510
diff
changeset
|
2826 | PurplePluginAction *act; |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2827 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2828 | gc = (PurpleConnection *)context; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2829 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2830 | menu = NULL; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2831 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2832 | #if 0 |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2833 | /* TODO: find out how */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2834 | act = purple_plugin_action_new(_("Find people..."), msim_); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2835 | menu = g_list_append(menu, act); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2836 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2837 | act = purple_plugin_action_new(_("Change IM name..."), NULL); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2838 | menu = g_list_append(menu, act); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2839 | #endif |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2840 | |
|
19512
040a04d43bbb
First half of "Add friends from MySpace.com" support: add msim_import_friends(),
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19510
diff
changeset
|
2841 | act = purple_plugin_action_new(g_strdup_printf("%s", |
|
040a04d43bbb
First half of "Add friends from MySpace.com" support: add msim_import_friends(),
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19510
diff
changeset
|
2842 | _("Add friends from MySpace.com")), msim_import_friends); |
|
040a04d43bbb
First half of "Add friends from MySpace.com" support: add msim_import_friends(),
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19510
diff
changeset
|
2843 | menu = g_list_append(menu, act); |
|
040a04d43bbb
First half of "Add friends from MySpace.com" support: add msim_import_friends(),
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19510
diff
changeset
|
2844 | |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2845 | return menu; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2846 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2847 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2848 | /** Callbacks called by Purple, to access this plugin. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2849 | PurplePluginProtocolInfo prpl_info = { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2850 | /* options */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2851 | OPT_PROTO_USE_POINTSIZE /* specify font size in sane point size */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2852 | | OPT_PROTO_MAIL_CHECK, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2853 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2854 | /* | OPT_PROTO_IM_IMAGE - TODO: direct images. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2855 | NULL, /* user_splits */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2856 | NULL, /* protocol_options */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2857 | NO_BUDDY_ICONS, /* icon_spec - TODO: eventually should add this */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2858 | msim_list_icon, /* list_icon */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2859 | NULL, /* list_emblems */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2860 | msim_status_text, /* status_text */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2861 | msim_tooltip_text, /* tooltip_text */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2862 | msim_status_types, /* status_types */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2863 | msim_blist_node_menu, /* blist_node_menu */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2864 | NULL, /* chat_info */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2865 | NULL, /* chat_info_defaults */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2866 | msim_login, /* login */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2867 | msim_close, /* close */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2868 | msim_send_im, /* send_im */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2869 | NULL, /* set_info */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2870 | msim_send_typing, /* send_typing */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2871 | msim_get_info, /* get_info */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2872 | msim_set_status, /* set_status */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2873 | msim_set_idle, /* set_idle */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2874 | NULL, /* change_passwd */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2875 | msim_add_buddy, /* add_buddy */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2876 | NULL, /* add_buddies */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2877 | msim_remove_buddy, /* remove_buddy */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2878 | NULL, /* remove_buddies */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2879 | NULL, /* add_permit */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2880 | NULL, /* add_deny */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2881 | NULL, /* rem_permit */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2882 | NULL, /* rem_deny */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2883 | NULL, /* set_permit_deny */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2884 | NULL, /* join_chat */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2885 | NULL, /* reject chat invite */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2886 | NULL, /* get_chat_name */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2887 | NULL, /* chat_invite */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2888 | NULL, /* chat_leave */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2889 | NULL, /* chat_whisper */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2890 | NULL, /* chat_send */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2891 | NULL, /* keepalive */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2892 | NULL, /* register_user */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2893 | NULL, /* get_cb_info */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2894 | NULL, /* get_cb_away */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2895 | NULL, /* alias_buddy */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2896 | NULL, /* group_buddy */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2897 | NULL, /* rename_group */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2898 | NULL, /* buddy_free */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2899 | NULL, /* convo_closed */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2900 | NULL, /* normalize */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2901 | NULL, /* set_buddy_icon */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2902 | NULL, /* remove_group */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2903 | NULL, /* get_cb_real_name */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2904 | NULL, /* set_chat_topic */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2905 | NULL, /* find_blist_chat */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2906 | NULL, /* roomlist_get_list */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2907 | NULL, /* roomlist_cancel */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2908 | NULL, /* roomlist_expand_category */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2909 | NULL, /* can_receive_file */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2910 | NULL, /* send_file */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2911 | NULL, /* new_xfer */ |
|
19506
0e4b5fe04c11
Re-apply the msimprpl-specific parts of revision
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19505
diff
changeset
|
2912 | msim_offline_message, /* offline_message */ |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2913 | NULL, /* whiteboard_prpl_ops */ |
|
19506
0e4b5fe04c11
Re-apply the msimprpl-specific parts of revision
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19505
diff
changeset
|
2914 | msim_send_really_raw, /* send_raw */ |
|
0e4b5fe04c11
Re-apply the msimprpl-specific parts of revision
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19505
diff
changeset
|
2915 | NULL, /* roomlist_room_serialize */ |
|
0e4b5fe04c11
Re-apply the msimprpl-specific parts of revision
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19505
diff
changeset
|
2916 | #ifdef MSIM_USE_ATTENTION_API |
|
0e4b5fe04c11
Re-apply the msimprpl-specific parts of revision
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19505
diff
changeset
|
2917 | msim_send_attention, /* send_attention */ |
|
0e4b5fe04c11
Re-apply the msimprpl-specific parts of revision
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19505
diff
changeset
|
2918 | msim_attention_types, /* attention_types */ |
|
0e4b5fe04c11
Re-apply the msimprpl-specific parts of revision
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19505
diff
changeset
|
2919 | #else |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2920 | NULL, /* _purple_reserved1 */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2921 | NULL, /* _purple_reserved2 */ |
|
19506
0e4b5fe04c11
Re-apply the msimprpl-specific parts of revision
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19505
diff
changeset
|
2922 | #endif |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2923 | NULL, /* _purple_reserved3 */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2924 | NULL /* _purple_reserved4 */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2925 | }; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2926 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2927 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2928 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2929 | /** Based on MSN's plugin info comments. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2930 | PurplePluginInfo info = { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2931 | PURPLE_PLUGIN_MAGIC, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2932 | PURPLE_MAJOR_VERSION, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2933 | PURPLE_MINOR_VERSION, |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2934 | PURPLE_PLUGIN_PROTOCOL, /**< type */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2935 | NULL, /**< ui_requirement */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2936 | 0, /**< flags */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2937 | NULL, /**< dependencies */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2938 | PURPLE_PRIORITY_DEFAULT, /**< priority */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2939 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2940 | "prpl-myspace", /**< id */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2941 | "MySpaceIM", /**< name */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2942 | MSIM_PRPL_VERSION_STRING, /**< version */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2943 | /** summary */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2944 | "MySpaceIM Protocol Plugin", |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2945 | /** description */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2946 | "MySpaceIM Protocol Plugin", |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2947 | "Jeff Connelly <jeff2@soc.pidgin.im>", /**< author */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2948 | "http://developer.pidgin.im/wiki/MySpaceIM/", /**< homepage */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2949 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2950 | msim_load, /**< load */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2951 | NULL, /**< unload */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2952 | NULL, /**< destroy */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2953 | NULL, /**< ui_info */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2954 | &prpl_info, /**< extra_info */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2955 | NULL, /**< prefs_info */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2956 | msim_actions, /**< msim_actions */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2957 | NULL, /**< reserved1 */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2958 | NULL, /**< reserved2 */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2959 | NULL, /**< reserved3 */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2960 | NULL /**< reserved4 */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2961 | }; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2962 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2963 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2964 | #ifdef MSIM_SELF_TEST |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2965 | /** Test functions. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2966 | * Used to test or try out the internal workings of msimprpl. If you're reading |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2967 | * this code for the first time, these functions can be instructive in learning |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2968 | * how msimprpl is architected. |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2969 | */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2970 | void |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2971 | msim_test_all(void) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2972 | guint failures; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2973 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2974 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2975 | failures = 0; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2976 | failures += msim_test_msg(); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2977 | failures += msim_test_escaping(); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2978 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2979 | if (failures) { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2980 | purple_debug_info("msim", "msim_test_all HAD FAILURES: %d\n", failures); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2981 | } else { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2982 | purple_debug_info("msim", "msim_test_all - all tests passed!\n"); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2983 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2984 | exit(0); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2985 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2986 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2987 | /** Test MsimMessage for basic functionality. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2988 | int |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2989 | msim_test_msg(void) |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2990 | { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2991 | MsimMessage *msg, *msg_cloned, *msg2; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2992 | GList *list; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2993 | gchar *packed, *packed_expected, *packed_cloned; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2994 | guint failures; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2995 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2996 | failures = 0; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2997 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2998 | purple_debug_info("msim", "\n\nTesting MsimMessage\n"); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
2999 | msg = msim_msg_new(NULL); /* Create a new, empty message. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3000 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3001 | /* Append some new elements. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3002 | msg = msim_msg_append(msg, "bx", MSIM_TYPE_BINARY, g_string_new_len(g_strdup("XXX"), 3)); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3003 | msg = msim_msg_append(msg, "k1", MSIM_TYPE_STRING, g_strdup("v1")); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3004 | msg = msim_msg_append(msg, "k1", MSIM_TYPE_INTEGER, GUINT_TO_POINTER(42)); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3005 | msg = msim_msg_append(msg, "k1", MSIM_TYPE_STRING, g_strdup("v43")); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3006 | msg = msim_msg_append(msg, "k1", MSIM_TYPE_STRING, g_strdup("v52/xxx\\yyy")); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3007 | msg = msim_msg_append(msg, "k1", MSIM_TYPE_STRING, g_strdup("v7")); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3008 | msim_msg_dump("msg debug str=%s\n", msg); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3009 | packed = msim_msg_pack(msg); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3010 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3011 | purple_debug_info("msim", "msg packed=%s\n", packed); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3012 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3013 | packed_expected = "\\bx\\WFhY\\k1\\v1\\k1\\42\\k1" |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3014 | "\\v43\\k1\\v52/1xxx/2yyy\\k1\\v7\\final\\"; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3015 | |
|
19606
afc90bd82e6d
In msimprpl, replace !strcmp() with g_str_equal() everywhere.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19605
diff
changeset
|
3016 | if (!g_str_equal(packed, packed_expected)) { |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3017 | purple_debug_info("msim", "!!!(%d), msim_msg_pack not what expected: %s != %s\n", |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3018 | ++failures, packed, packed_expected); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3019 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3020 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3021 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3022 | msg_cloned = msim_msg_clone(msg); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3023 | packed_cloned = msim_msg_pack(msg_cloned); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3024 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3025 | purple_debug_info("msim", "msg cloned=%s\n", packed_cloned); |
|
19606
afc90bd82e6d
In msimprpl, replace !strcmp() with g_str_equal() everywhere.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19605
diff
changeset
|
3026 | if (!g_str_equal(packed, packed_cloned)) { |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3027 | purple_debug_info("msim", "!!!(%d), msim_msg_pack on cloned message not equal to original: %s != %s\n", |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3028 | ++failures, packed_cloned, packed); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3029 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3030 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3031 | g_free(packed); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3032 | g_free(packed_cloned); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3033 | msim_msg_free(msg_cloned); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3034 | msim_msg_free(msg); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3035 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3036 | /* Try some of the more advanced functionality */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3037 | list = NULL; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3038 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3039 | list = g_list_prepend(list, "item3"); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3040 | list = g_list_prepend(list, "item2"); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3041 | list = g_list_prepend(list, "item1"); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3042 | list = g_list_prepend(list, "item0"); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3043 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3044 | msg = msim_msg_new(NULL); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3045 | msg = msim_msg_append(msg, "string", MSIM_TYPE_STRING, g_strdup("string value")); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3046 | msg = msim_msg_append(msg, "raw", MSIM_TYPE_RAW, g_strdup("raw value")); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3047 | msg = msim_msg_append(msg, "integer", MSIM_TYPE_INTEGER, GUINT_TO_POINTER(3140)); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3048 | msg = msim_msg_append(msg, "boolean", MSIM_TYPE_BOOLEAN, GUINT_TO_POINTER(FALSE)); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3049 | msg = msim_msg_append(msg, "list", MSIM_TYPE_LIST, list); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3050 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3051 | msim_msg_dump("msg with list=%s\n", msg); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3052 | purple_debug_info("msim", "msg with list packed=%s\n", msim_msg_pack(msg)); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3053 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3054 | msg2 = msim_msg_new(NULL); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3055 | msg2 = msim_msg_append(msg2, "outer", MSIM_TYPE_STRING, g_strdup("outer value")); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3056 | msg2 = msim_msg_append(msg2, "body", MSIM_TYPE_DICTIONARY, msg); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3057 | msim_msg_dump("msg with dict=%s\n", msg2); /* msg2 now 'owns' msg */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3058 | purple_debug_info("msim", "msg with dict packed=%s\n", msim_msg_pack(msg2)); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3059 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3060 | msim_msg_free(msg2); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3061 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3062 | return failures; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3063 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3064 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3065 | /** Test protocol-level escaping/unescaping. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3066 | int |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3067 | msim_test_escaping(void) |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3068 | { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3069 | guint failures; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3070 | gchar *raw, *escaped, *unescaped, *expected; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3071 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3072 | failures = 0; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3073 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3074 | purple_debug_info("msim", "\n\nTesting escaping\n"); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3075 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3076 | raw = "hello/world\\hello/world"; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3077 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3078 | escaped = msim_escape(raw); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3079 | purple_debug_info("msim", "msim_test_escaping: raw=%s, escaped=%s\n", raw, escaped); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3080 | expected = "hello/1world/2hello/1world"; |
|
19606
afc90bd82e6d
In msimprpl, replace !strcmp() with g_str_equal() everywhere.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19605
diff
changeset
|
3081 | if (!g_str_equal(escaped, expected)) { |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3082 | purple_debug_info("msim", "!!!(%d), msim_escape failed: %s != %s\n", |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3083 | ++failures, escaped, expected); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3084 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3085 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3086 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3087 | unescaped = msim_unescape(escaped); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3088 | g_free(escaped); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3089 | purple_debug_info("msim", "msim_test_escaping: unescaped=%s\n", unescaped); |
|
19606
afc90bd82e6d
In msimprpl, replace !strcmp() with g_str_equal() everywhere.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19605
diff
changeset
|
3090 | if (!g_str_equal(raw, unescaped)) { |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3091 | purple_debug_info("msim", "!!!(%d), msim_unescape failed: %s != %s\n", |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3092 | ++failures, raw, unescaped); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3093 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3094 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3095 | return failures; |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3096 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3097 | #endif |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3098 | |
|
19620
238f24594c04
Add msim_uri_handler() to handle myim: URLs, sendIM and addContact commands.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19619
diff
changeset
|
3099 | static gboolean |
|
238f24594c04
Add msim_uri_handler() to handle myim: URLs, sendIM and addContact commands.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19619
diff
changeset
|
3100 | msim_uri_handler(const gchar *proto, const gchar *cmd, GHashTable *params) |
|
238f24594c04
Add msim_uri_handler() to handle myim: URLs, sendIM and addContact commands.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19619
diff
changeset
|
3101 | { |
|
238f24594c04
Add msim_uri_handler() to handle myim: URLs, sendIM and addContact commands.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19619
diff
changeset
|
3102 | PurpleAccount *account; |
|
19633
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3103 | MsimSession *session; |
|
19620
238f24594c04
Add msim_uri_handler() to handle myim: URLs, sendIM and addContact commands.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19619
diff
changeset
|
3104 | GList *l; |
|
238f24594c04
Add msim_uri_handler() to handle myim: URLs, sendIM and addContact commands.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19619
diff
changeset
|
3105 | gchar *uid_str, *cid_str; |
|
238f24594c04
Add msim_uri_handler() to handle myim: URLs, sendIM and addContact commands.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19619
diff
changeset
|
3106 | guint uid, cid; |
|
238f24594c04
Add msim_uri_handler() to handle myim: URLs, sendIM and addContact commands.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19619
diff
changeset
|
3107 | |
|
238f24594c04
Add msim_uri_handler() to handle myim: URLs, sendIM and addContact commands.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19619
diff
changeset
|
3108 | if (g_ascii_strcasecmp(proto, "myim")) |
|
238f24594c04
Add msim_uri_handler() to handle myim: URLs, sendIM and addContact commands.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19619
diff
changeset
|
3109 | return FALSE; |
|
238f24594c04
Add msim_uri_handler() to handle myim: URLs, sendIM and addContact commands.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19619
diff
changeset
|
3110 | |
|
19625
b9a2aa87bc27
In msimprpl, fix the msim_uri_handler(). The sendIM and addContact commands
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19621
diff
changeset
|
3111 | /* Parameters are case-insensitive. */ |
|
b9a2aa87bc27
In msimprpl, fix the msim_uri_handler(). The sendIM and addContact commands
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19621
diff
changeset
|
3112 | uid_str = g_hash_table_lookup(params, "uid"); |
|
b9a2aa87bc27
In msimprpl, fix the msim_uri_handler(). The sendIM and addContact commands
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19621
diff
changeset
|
3113 | cid_str = g_hash_table_lookup(params, "cid"); |
|
19620
238f24594c04
Add msim_uri_handler() to handle myim: URLs, sendIM and addContact commands.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19619
diff
changeset
|
3114 | |
|
238f24594c04
Add msim_uri_handler() to handle myim: URLs, sendIM and addContact commands.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19619
diff
changeset
|
3115 | uid = uid_str ? atol(uid_str) : 0; |
|
238f24594c04
Add msim_uri_handler() to handle myim: URLs, sendIM and addContact commands.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19619
diff
changeset
|
3116 | cid = cid_str ? atol(cid_str) : 0; |
|
238f24594c04
Add msim_uri_handler() to handle myim: URLs, sendIM and addContact commands.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19619
diff
changeset
|
3117 | |
|
19625
b9a2aa87bc27
In msimprpl, fix the msim_uri_handler(). The sendIM and addContact commands
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19621
diff
changeset
|
3118 | /* Need a contact. */ |
|
b9a2aa87bc27
In msimprpl, fix the msim_uri_handler(). The sendIM and addContact commands
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19621
diff
changeset
|
3119 | g_return_val_if_fail(cid != 0, FALSE); |
|
b9a2aa87bc27
In msimprpl, fix the msim_uri_handler(). The sendIM and addContact commands
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19621
diff
changeset
|
3120 | |
|
19634
30bbe39b35db
In msimprpl: if no local alias is set, set it to the username on sign-on.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19633
diff
changeset
|
3121 | /* TODO: if auto=true, "Add all the people on this page to my IM List!", on |
|
30bbe39b35db
In msimprpl: if no local alias is set, set it to the username on sign-on.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19633
diff
changeset
|
3122 | * http://collect.myspace.com/index.cfm?fuseaction=im.friendslist. Don't need a cid. */ |
|
30bbe39b35db
In msimprpl: if no local alias is set, set it to the username on sign-on.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19633
diff
changeset
|
3123 | |
|
19633
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3124 | /* Convert numeric contact ID back to a string. Needed for looking up. Don't just |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3125 | * directly use cid directly from parameters, because it might not be numeric. |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3126 | * It is trivial to change this to allow cID to be a username, but that's not how |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3127 | * the official MySpaceIM client works, so don't provide that functionality. */ |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3128 | cid_str = g_strdup_printf("%d", cid); |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3129 | |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3130 | |
|
19620
238f24594c04
Add msim_uri_handler() to handle myim: URLs, sendIM and addContact commands.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19619
diff
changeset
|
3131 | /* Find our account with specified user id, or use first connected account if uid=0. */ |
|
238f24594c04
Add msim_uri_handler() to handle myim: URLs, sendIM and addContact commands.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19619
diff
changeset
|
3132 | account = NULL; |
|
238f24594c04
Add msim_uri_handler() to handle myim: URLs, sendIM and addContact commands.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19619
diff
changeset
|
3133 | l = purple_accounts_get_all(); |
|
238f24594c04
Add msim_uri_handler() to handle myim: URLs, sendIM and addContact commands.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19619
diff
changeset
|
3134 | while (l) { |
|
238f24594c04
Add msim_uri_handler() to handle myim: URLs, sendIM and addContact commands.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19619
diff
changeset
|
3135 | if (purple_account_is_connected(l->data) && |
|
238f24594c04
Add msim_uri_handler() to handle myim: URLs, sendIM and addContact commands.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19619
diff
changeset
|
3136 | (uid == 0 || purple_account_get_int(l->data, "uid", 0) == uid)) { |
|
238f24594c04
Add msim_uri_handler() to handle myim: URLs, sendIM and addContact commands.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19619
diff
changeset
|
3137 | account = l->data; |
|
238f24594c04
Add msim_uri_handler() to handle myim: URLs, sendIM and addContact commands.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19619
diff
changeset
|
3138 | break; |
|
238f24594c04
Add msim_uri_handler() to handle myim: URLs, sendIM and addContact commands.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19619
diff
changeset
|
3139 | } |
|
238f24594c04
Add msim_uri_handler() to handle myim: URLs, sendIM and addContact commands.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19619
diff
changeset
|
3140 | l = l->next; |
|
238f24594c04
Add msim_uri_handler() to handle myim: URLs, sendIM and addContact commands.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19619
diff
changeset
|
3141 | } |
|
238f24594c04
Add msim_uri_handler() to handle myim: URLs, sendIM and addContact commands.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19619
diff
changeset
|
3142 | |
|
238f24594c04
Add msim_uri_handler() to handle myim: URLs, sendIM and addContact commands.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19619
diff
changeset
|
3143 | if (!account) { |
|
238f24594c04
Add msim_uri_handler() to handle myim: URLs, sendIM and addContact commands.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19619
diff
changeset
|
3144 | purple_notify_error(NULL, _("myim URL handler"), |
|
238f24594c04
Add msim_uri_handler() to handle myim: URLs, sendIM and addContact commands.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19619
diff
changeset
|
3145 | _("No suitable MySpaceIM account could be found to open this myim URL."), |
|
238f24594c04
Add msim_uri_handler() to handle myim: URLs, sendIM and addContact commands.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19619
diff
changeset
|
3146 | _("Enable the proper MySpaceIM account and try again.")); |
|
19633
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3147 | g_free(cid_str); |
|
19620
238f24594c04
Add msim_uri_handler() to handle myim: URLs, sendIM and addContact commands.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19619
diff
changeset
|
3148 | return FALSE; |
|
238f24594c04
Add msim_uri_handler() to handle myim: URLs, sendIM and addContact commands.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19619
diff
changeset
|
3149 | } |
|
238f24594c04
Add msim_uri_handler() to handle myim: URLs, sendIM and addContact commands.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19619
diff
changeset
|
3150 | |
|
19633
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3151 | session = (MsimSession *)account->gc->proto_data; |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3152 | g_return_val_if_fail(session != NULL, FALSE); |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3153 | |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3154 | /* Lookup userid to username. TODO: push this down, to IM sending/contact |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3155 | * adding functions. */ |
|
19625
b9a2aa87bc27
In msimprpl, fix the msim_uri_handler(). The sendIM and addContact commands
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19621
diff
changeset
|
3156 | |
|
19620
238f24594c04
Add msim_uri_handler() to handle myim: URLs, sendIM and addContact commands.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19619
diff
changeset
|
3157 | /* myim:sendIM?uID=USERID&cID=CONTACTID */ |
|
238f24594c04
Add msim_uri_handler() to handle myim: URLs, sendIM and addContact commands.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19619
diff
changeset
|
3158 | if (!g_ascii_strcasecmp(cmd, "sendIM")) { |
|
19633
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3159 | msim_lookup_user(session, cid_str, (MSIM_USER_LOOKUP_CB)msim_uri_handler_sendIM_cb, NULL); |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3160 | g_free(cid_str); |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3161 | return TRUE; |
|
19620
238f24594c04
Add msim_uri_handler() to handle myim: URLs, sendIM and addContact commands.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19619
diff
changeset
|
3162 | |
|
238f24594c04
Add msim_uri_handler() to handle myim: URLs, sendIM and addContact commands.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19619
diff
changeset
|
3163 | /* myim:addContact?uID=USERID&cID=CONTACTID */ |
|
238f24594c04
Add msim_uri_handler() to handle myim: URLs, sendIM and addContact commands.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19619
diff
changeset
|
3164 | } else if (!g_ascii_strcasecmp(cmd, "addContact")) { |
|
19633
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3165 | msim_lookup_user(session, cid_str, (MSIM_USER_LOOKUP_CB)msim_uri_handler_addContact_cb, NULL); |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3166 | g_free(cid_str); |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3167 | return TRUE; |
|
19620
238f24594c04
Add msim_uri_handler() to handle myim: URLs, sendIM and addContact commands.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19619
diff
changeset
|
3168 | } |
|
238f24594c04
Add msim_uri_handler() to handle myim: URLs, sendIM and addContact commands.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19619
diff
changeset
|
3169 | |
|
238f24594c04
Add msim_uri_handler() to handle myim: URLs, sendIM and addContact commands.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19619
diff
changeset
|
3170 | return FALSE; |
|
238f24594c04
Add msim_uri_handler() to handle myim: URLs, sendIM and addContact commands.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19619
diff
changeset
|
3171 | } |
|
238f24594c04
Add msim_uri_handler() to handle myim: URLs, sendIM and addContact commands.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19619
diff
changeset
|
3172 | |
|
19633
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3173 | /* TODO: move uid->username resolving to IM sending and buddy adding functions, |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3174 | * so that user can manually add or IM by userid and username automatically |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3175 | * looked up if possible? */ |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3176 | |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3177 | /** Handle a myim:sendIM URI command, after username has been looked up. */ |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3178 | static void |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3179 | msim_uri_handler_sendIM_cb(MsimSession *session, MsimMessage *userinfo, gpointer data) |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3180 | { |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3181 | PurpleConversation *conv; |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3182 | MsimMessage *body; |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3183 | gchar *username; |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3184 | |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3185 | body = msim_msg_get_dictionary(userinfo, "body"); |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3186 | username = msim_msg_get_string(body, "UserName"); |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3187 | msim_msg_free(body); |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3188 | |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3189 | if (!username) { |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3190 | guint uid; |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3191 | |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3192 | uid = msim_msg_get_integer(userinfo, "UserID"); |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3193 | g_return_if_fail(uid != 0); |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3194 | |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3195 | username = g_strdup_printf("%d", uid); |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3196 | } |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3197 | |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3198 | |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3199 | conv = purple_find_conversation_with_account(PURPLE_CONV_TYPE_IM, username, session->account); |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3200 | if (!conv) { |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3201 | purple_debug_info("msim_uri_handler", "creating new conversation for %s\n", username); |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3202 | conv = purple_conversation_new(PURPLE_CONV_TYPE_IM, session->account, username); |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3203 | } |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3204 | |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3205 | /* Just open the window so the user can send an IM. */ |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3206 | purple_conversation_present(conv); |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3207 | |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3208 | g_free(username); |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3209 | } |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3210 | |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3211 | /** Handle a myim:addContact command, after username has been looked up. */ |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3212 | static void |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3213 | msim_uri_handler_addContact_cb(MsimSession *session, MsimMessage *userinfo, gpointer data) |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3214 | { |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3215 | MsimMessage *body; |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3216 | gchar *username; |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3217 | |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3218 | body = msim_msg_get_dictionary(userinfo, "body"); |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3219 | username = msim_msg_get_string(body, "UserName"); |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3220 | msim_msg_free(body); |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3221 | |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3222 | if (!username) { |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3223 | guint uid; |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3224 | |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3225 | uid = msim_msg_get_integer(userinfo, "UserID"); |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3226 | g_return_if_fail(uid != 0); |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3227 | |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3228 | username = g_strdup_printf("%d", uid); |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3229 | } |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3230 | |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3231 | |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3232 | purple_blist_request_add_buddy(session->account, username, _("Buddies"), NULL); |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3233 | |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3234 | g_free(username); |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3235 | } |
|
ad1278e9223f
For myim: (MySpaceIM) URLs, lookup the contact ID into a username before
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19625
diff
changeset
|
3236 | |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3237 | /** Initialize plugin. */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3238 | void |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3239 | init_plugin(PurplePlugin *plugin) |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3240 | { |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3241 | #ifdef MSIM_SELF_TEST |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3242 | msim_test_all(); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3243 | exit(0); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3244 | #endif /* MSIM_SELF_TEST */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3245 | |
|
19620
238f24594c04
Add msim_uri_handler() to handle myim: URLs, sendIM and addContact commands.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19619
diff
changeset
|
3246 | PurpleAccountOption *option; |
|
238f24594c04
Add msim_uri_handler() to handle myim: URLs, sendIM and addContact commands.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19619
diff
changeset
|
3247 | static gboolean initialized = FALSE; |
|
238f24594c04
Add msim_uri_handler() to handle myim: URLs, sendIM and addContact commands.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19619
diff
changeset
|
3248 | |
|
19741
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
3249 | #ifdef MSIM_CHECK_NEWER_VERSION |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
3250 | /* PROBLEM: MySpace's servers always return Content-Location, and |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
3251 | * libpurple redirects to it, infinitely, even though it is the same |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
3252 | * location we requested! */ |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
3253 | purple_util_fetch_url("http://im.myspace.com/nsis/currentversion.txt", |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
3254 | FALSE, /* not full URL */ |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
3255 | "MSIMAutoUpdateAgent", /* user agent */ |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
3256 | TRUE, /* use HTTP/1.1 */ |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
3257 | msim_check_newer_version_cb, NULL); |
|
f6f0aff2ef68
If MSIM_CHECK_NEWER_VERSION is defined (off by default), run (incomplete)
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19740
diff
changeset
|
3258 | #endif |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3259 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3260 | /* TODO: default to automatically try different ports. Make the user be |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3261 | * able to set the first port to try (like LastConnectedPort in Windows client). */ |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3262 | option = purple_account_option_string_new(_("Connect server"), "server", MSIM_SERVER); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3263 | prpl_info.protocol_options = g_list_append(prpl_info.protocol_options, option); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3264 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3265 | option = purple_account_option_int_new(_("Connect port"), "port", MSIM_PORT); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3266 | prpl_info.protocol_options = g_list_append(prpl_info.protocol_options, option); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3267 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3268 | #ifdef MSIM_USER_WANTS_TO_CONFIGURE_STATUS_TEXT |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3269 | option = purple_account_option_bool_new(_("Show display name in status text"), "show_display_name", TRUE); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3270 | prpl_info.protocol_options = g_list_append(prpl_info.protocol_options, option); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3271 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3272 | option = purple_account_option_bool_new(_("Show headline in status text"), "show_headline", TRUE); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3273 | prpl_info.protocol_options = g_list_append(prpl_info.protocol_options, option); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3274 | #endif |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3275 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3276 | #ifdef MSIM_USER_WANTS_TO_DISABLE_EMOTICONS |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3277 | option = purple_account_option_bool_new(_("Send emoticons"), "emoticons", FALSE); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3278 | prpl_info.protocol_options = g_list_append(prpl_info.protocol_options, option); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3279 | #endif |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3280 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3281 | #ifdef MSIM_USER_REALLY_CARES_ABOUT_PRECISE_FONT_SIZES |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3282 | option = purple_account_option_int_new(_("Screen resolution (dots per inch)"), "dpi", MSIM_DEFAULT_DPI); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3283 | prpl_info.protocol_options = g_list_append(prpl_info.protocol_options, option); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3284 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3285 | option = purple_account_option_int_new(_("Base font size (points)"), "base_font_size", MSIM_BASE_FONT_POINT_SIZE); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3286 | prpl_info.protocol_options = g_list_append(prpl_info.protocol_options, option); |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3287 | #endif |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3288 | |
|
19620
238f24594c04
Add msim_uri_handler() to handle myim: URLs, sendIM and addContact commands.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19619
diff
changeset
|
3289 | /* Code below only runs once. Based on oscar.c's oscar_init(). */ |
|
238f24594c04
Add msim_uri_handler() to handle myim: URLs, sendIM and addContact commands.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19619
diff
changeset
|
3290 | if (initialized) |
|
238f24594c04
Add msim_uri_handler() to handle myim: URLs, sendIM and addContact commands.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19619
diff
changeset
|
3291 | return; |
|
238f24594c04
Add msim_uri_handler() to handle myim: URLs, sendIM and addContact commands.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19619
diff
changeset
|
3292 | |
|
238f24594c04
Add msim_uri_handler() to handle myim: URLs, sendIM and addContact commands.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19619
diff
changeset
|
3293 | initialized = TRUE; |
|
238f24594c04
Add msim_uri_handler() to handle myim: URLs, sendIM and addContact commands.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19619
diff
changeset
|
3294 | |
|
238f24594c04
Add msim_uri_handler() to handle myim: URLs, sendIM and addContact commands.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19619
diff
changeset
|
3295 | purple_signal_connect(purple_get_core(), "uri-handler", &initialized, |
|
238f24594c04
Add msim_uri_handler() to handle myim: URLs, sendIM and addContact commands.
Jeff Connelly <jeff2@soc.pidgin.im>
parents:
19619
diff
changeset
|
3296 | PURPLE_CALLBACK(msim_uri_handler), NULL); |
|
19505
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3297 | } |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3298 | |
|
6199132c5266
merge of 'a721a4962093ce576eac6814370da699026c2036'
Jeff Connelly <jeff2@soc.pidgin.im>
diff
changeset
|
3299 | PURPLE_INIT_PLUGIN(myspace, init_plugin, info); |