Mercurial > pidgin
annotate src/protocols/msn/userlist.c @ 19794:b22d13f55232
[gaim-migrate @ 16684]
change the code of SOAP Action,Now using a stupid way to do the soap,
wish to implement it in a clean way!
borrow a strptime to parse the timestamp received from MSN Server.
committed by MaYuan<mayuan2006@gmail.com>
committer: Ethan Blanton <elb@pidgin.im>
author | Ma Yuan <mayuan2006@gmail.com> |
---|---|
date | Thu, 10 Aug 2006 04:38:13 +0000 |
parents | bddd32f36bde |
children | 38e4a4b404e5 |
rev | line source |
---|---|
9198
ab6636c5a136
[gaim-migrate @ 9993]
Christian Hammond <chipx86@chipx86.com>
parents:
9197
diff
changeset
|
1 /** |
ab6636c5a136
[gaim-migrate @ 9993]
Christian Hammond <chipx86@chipx86.com>
parents:
9197
diff
changeset
|
2 * @file userlist.c MSN user list support |
ab6636c5a136
[gaim-migrate @ 9993]
Christian Hammond <chipx86@chipx86.com>
parents:
9197
diff
changeset
|
3 * |
ab6636c5a136
[gaim-migrate @ 9993]
Christian Hammond <chipx86@chipx86.com>
parents:
9197
diff
changeset
|
4 * gaim |
ab6636c5a136
[gaim-migrate @ 9993]
Christian Hammond <chipx86@chipx86.com>
parents:
9197
diff
changeset
|
5 * |
ab6636c5a136
[gaim-migrate @ 9993]
Christian Hammond <chipx86@chipx86.com>
parents:
9197
diff
changeset
|
6 * Gaim is the legal property of its developers, whose names are too numerous |
ab6636c5a136
[gaim-migrate @ 9993]
Christian Hammond <chipx86@chipx86.com>
parents:
9197
diff
changeset
|
7 * to list here. Please refer to the COPYRIGHT file distributed with this |
ab6636c5a136
[gaim-migrate @ 9993]
Christian Hammond <chipx86@chipx86.com>
parents:
9197
diff
changeset
|
8 * source distribution. |
ab6636c5a136
[gaim-migrate @ 9993]
Christian Hammond <chipx86@chipx86.com>
parents:
9197
diff
changeset
|
9 * |
ab6636c5a136
[gaim-migrate @ 9993]
Christian Hammond <chipx86@chipx86.com>
parents:
9197
diff
changeset
|
10 * This program is free software; you can redistribute it and/or modify |
ab6636c5a136
[gaim-migrate @ 9993]
Christian Hammond <chipx86@chipx86.com>
parents:
9197
diff
changeset
|
11 * it under the terms of the GNU General Public License as published by |
ab6636c5a136
[gaim-migrate @ 9993]
Christian Hammond <chipx86@chipx86.com>
parents:
9197
diff
changeset
|
12 * the Free Software Foundation; either version 2 of the License, or |
ab6636c5a136
[gaim-migrate @ 9993]
Christian Hammond <chipx86@chipx86.com>
parents:
9197
diff
changeset
|
13 * (at your option) any later version. |
ab6636c5a136
[gaim-migrate @ 9993]
Christian Hammond <chipx86@chipx86.com>
parents:
9197
diff
changeset
|
14 * |
ab6636c5a136
[gaim-migrate @ 9993]
Christian Hammond <chipx86@chipx86.com>
parents:
9197
diff
changeset
|
15 * This program is distributed in the hope that it will be useful, |
ab6636c5a136
[gaim-migrate @ 9993]
Christian Hammond <chipx86@chipx86.com>
parents:
9197
diff
changeset
|
16 * but WITHOUT ANY WARRANTY; without even the implied warranty of |
ab6636c5a136
[gaim-migrate @ 9993]
Christian Hammond <chipx86@chipx86.com>
parents:
9197
diff
changeset
|
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
ab6636c5a136
[gaim-migrate @ 9993]
Christian Hammond <chipx86@chipx86.com>
parents:
9197
diff
changeset
|
18 * GNU General Public License for more details. |
ab6636c5a136
[gaim-migrate @ 9993]
Christian Hammond <chipx86@chipx86.com>
parents:
9197
diff
changeset
|
19 * |
ab6636c5a136
[gaim-migrate @ 9993]
Christian Hammond <chipx86@chipx86.com>
parents:
9197
diff
changeset
|
20 * You should have received a copy of the GNU General Public License |
ab6636c5a136
[gaim-migrate @ 9993]
Christian Hammond <chipx86@chipx86.com>
parents:
9197
diff
changeset
|
21 * along with this program; if not, write to the Free Software |
ab6636c5a136
[gaim-migrate @ 9993]
Christian Hammond <chipx86@chipx86.com>
parents:
9197
diff
changeset
|
22 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA |
ab6636c5a136
[gaim-migrate @ 9993]
Christian Hammond <chipx86@chipx86.com>
parents:
9197
diff
changeset
|
23 */ |
9193 | 24 #include "msn.h" |
25 #include "userlist.h" | |
26 | |
27 const char *lists[] = { "FL", "AL", "BL", "RL" }; | |
28 | |
29 typedef struct | |
30 { | |
31 GaimConnection *gc; | |
32 char *who; | |
12380
553dd80f6130
[gaim-migrate @ 14684]
Daniel Atallah <daniel.atallah@gmail.com>
parents:
12318
diff
changeset
|
33 char *friendly; |
9193 | 34 |
35 } MsnPermitAdd; | |
36 | |
37 /************************************************************************** | |
38 * Callbacks | |
39 **************************************************************************/ | |
40 static void | |
41 msn_accept_add_cb(MsnPermitAdd *pa) | |
42 { | |
43 if (g_list_find(gaim_connections_get_all(), pa->gc) != NULL) | |
44 { | |
45 MsnSession *session = pa->gc->proto_data; | |
46 MsnUserList *userlist = session->userlist; | |
12380
553dd80f6130
[gaim-migrate @ 14684]
Daniel Atallah <daniel.atallah@gmail.com>
parents:
12318
diff
changeset
|
47 GaimBuddy *buddy; |
9193 | 48 |
49 msn_userlist_add_buddy(userlist, pa->who, MSN_LIST_AL, NULL); | |
50 | |
12380
553dd80f6130
[gaim-migrate @ 14684]
Daniel Atallah <daniel.atallah@gmail.com>
parents:
12318
diff
changeset
|
51 buddy = gaim_find_buddy(pa->gc->account, pa->who); |
553dd80f6130
[gaim-migrate @ 14684]
Daniel Atallah <daniel.atallah@gmail.com>
parents:
12318
diff
changeset
|
52 |
553dd80f6130
[gaim-migrate @ 14684]
Daniel Atallah <daniel.atallah@gmail.com>
parents:
12318
diff
changeset
|
53 if (buddy != NULL) |
553dd80f6130
[gaim-migrate @ 14684]
Daniel Atallah <daniel.atallah@gmail.com>
parents:
12318
diff
changeset
|
54 gaim_account_notify_added(pa->gc->account, pa->who, |
553dd80f6130
[gaim-migrate @ 14684]
Daniel Atallah <daniel.atallah@gmail.com>
parents:
12318
diff
changeset
|
55 NULL, pa->friendly, NULL); |
553dd80f6130
[gaim-migrate @ 14684]
Daniel Atallah <daniel.atallah@gmail.com>
parents:
12318
diff
changeset
|
56 else |
553dd80f6130
[gaim-migrate @ 14684]
Daniel Atallah <daniel.atallah@gmail.com>
parents:
12318
diff
changeset
|
57 gaim_account_request_add(pa->gc->account, pa->who, |
553dd80f6130
[gaim-migrate @ 14684]
Daniel Atallah <daniel.atallah@gmail.com>
parents:
12318
diff
changeset
|
58 NULL, pa->friendly, NULL); |
9193 | 59 } |
60 | |
61 g_free(pa->who); | |
12380
553dd80f6130
[gaim-migrate @ 14684]
Daniel Atallah <daniel.atallah@gmail.com>
parents:
12318
diff
changeset
|
62 g_free(pa->friendly); |
9193 | 63 g_free(pa); |
64 } | |
65 | |
66 static void | |
67 msn_cancel_add_cb(MsnPermitAdd *pa) | |
68 { | |
69 if (g_list_find(gaim_connections_get_all(), pa->gc) != NULL) | |
70 { | |
71 MsnSession *session = pa->gc->proto_data; | |
72 MsnUserList *userlist = session->userlist; | |
73 | |
74 msn_userlist_add_buddy(userlist, pa->who, MSN_LIST_BL, NULL); | |
75 } | |
76 | |
77 g_free(pa->who); | |
12380
553dd80f6130
[gaim-migrate @ 14684]
Daniel Atallah <daniel.atallah@gmail.com>
parents:
12318
diff
changeset
|
78 g_free(pa->friendly); |
9193 | 79 g_free(pa); |
80 } | |
81 | |
82 static void | |
9976 | 83 got_new_entry(GaimConnection *gc, const char *passport, const char *friendly) |
9193 | 84 { |
85 MsnPermitAdd *pa; | |
10774 | 86 char *msg; |
9193 | 87 |
12380
553dd80f6130
[gaim-migrate @ 14684]
Daniel Atallah <daniel.atallah@gmail.com>
parents:
12318
diff
changeset
|
88 pa = g_new0(MsnPermitAdd, 1); |
9193 | 89 pa->who = g_strdup(passport); |
12381 | 90 pa->friendly = g_strdup(friendly); |
12380
553dd80f6130
[gaim-migrate @ 14684]
Daniel Atallah <daniel.atallah@gmail.com>
parents:
12318
diff
changeset
|
91 pa->gc = gc; |
9193 | 92 |
9210
62b601ddb4bc
[gaim-migrate @ 10005]
Christian Hammond <chipx86@chipx86.com>
parents:
9208
diff
changeset
|
93 if (friendly != NULL) |
62b601ddb4bc
[gaim-migrate @ 10005]
Christian Hammond <chipx86@chipx86.com>
parents:
9208
diff
changeset
|
94 { |
62b601ddb4bc
[gaim-migrate @ 10005]
Christian Hammond <chipx86@chipx86.com>
parents:
9208
diff
changeset
|
95 msg = g_strdup_printf( |
62b601ddb4bc
[gaim-migrate @ 10005]
Christian Hammond <chipx86@chipx86.com>
parents:
9208
diff
changeset
|
96 _("The user %s (%s) wants to add %s to his or her " |
62b601ddb4bc
[gaim-migrate @ 10005]
Christian Hammond <chipx86@chipx86.com>
parents:
9208
diff
changeset
|
97 "buddy list."), |
10774 | 98 passport, friendly, |
9210
62b601ddb4bc
[gaim-migrate @ 10005]
Christian Hammond <chipx86@chipx86.com>
parents:
9208
diff
changeset
|
99 gaim_account_get_username(gc->account)); |
62b601ddb4bc
[gaim-migrate @ 10005]
Christian Hammond <chipx86@chipx86.com>
parents:
9208
diff
changeset
|
100 } |
62b601ddb4bc
[gaim-migrate @ 10005]
Christian Hammond <chipx86@chipx86.com>
parents:
9208
diff
changeset
|
101 else |
62b601ddb4bc
[gaim-migrate @ 10005]
Christian Hammond <chipx86@chipx86.com>
parents:
9208
diff
changeset
|
102 { |
62b601ddb4bc
[gaim-migrate @ 10005]
Christian Hammond <chipx86@chipx86.com>
parents:
9208
diff
changeset
|
103 msg = g_strdup_printf( |
62b601ddb4bc
[gaim-migrate @ 10005]
Christian Hammond <chipx86@chipx86.com>
parents:
9208
diff
changeset
|
104 _("The user %s wants to add %s to his or " |
62b601ddb4bc
[gaim-migrate @ 10005]
Christian Hammond <chipx86@chipx86.com>
parents:
9208
diff
changeset
|
105 "her buddy list."), |
62b601ddb4bc
[gaim-migrate @ 10005]
Christian Hammond <chipx86@chipx86.com>
parents:
9208
diff
changeset
|
106 passport, gaim_account_get_username(gc->account)); |
62b601ddb4bc
[gaim-migrate @ 10005]
Christian Hammond <chipx86@chipx86.com>
parents:
9208
diff
changeset
|
107 } |
9193 | 108 |
9976 | 109 gaim_request_action(gc, NULL, msg, NULL, |
9948 | 110 GAIM_DEFAULT_ACTION_NONE, pa, 2, |
9193 | 111 _("Authorize"), G_CALLBACK(msn_accept_add_cb), |
112 _("Deny"), G_CALLBACK(msn_cancel_add_cb)); | |
113 | |
114 g_free(msg); | |
115 } | |
116 | |
117 /************************************************************************** | |
118 * Utility functions | |
119 **************************************************************************/ | |
120 | |
121 static gboolean | |
19785 | 122 user_is_in_group(MsnUser *user, const char * group_id) |
9193 | 123 { |
124 if (user == NULL) | |
125 return FALSE; | |
126 | |
19785 | 127 if (group_id == NULL) |
9193 | 128 return FALSE; |
129 | |
19785 | 130 if (g_list_find(user->group_ids, group_id)) |
9193 | 131 return TRUE; |
132 | |
133 return FALSE; | |
134 } | |
135 | |
136 static gboolean | |
19785 | 137 user_is_there(MsnUser *user, int list_id, const char * group_id) |
9193 | 138 { |
139 int list_op; | |
140 | |
141 if (user == NULL) | |
142 return FALSE; | |
143 | |
144 list_op = 1 << list_id; | |
145 | |
146 if (!(user->list_op & list_op)) | |
147 return FALSE; | |
148 | |
19785 | 149 if (list_id == MSN_LIST_FL){ |
150 if (group_id != NULL) | |
9193 | 151 return user_is_in_group(user, group_id); |
152 } | |
153 | |
154 return TRUE; | |
155 } | |
156 | |
157 static const char* | |
158 get_store_name(MsnUser *user) | |
159 { | |
160 const char *store_name; | |
161 | |
162 g_return_val_if_fail(user != NULL, NULL); | |
163 | |
10533 | 164 store_name = msn_user_get_store_name(user); |
165 | |
166 if (store_name != NULL) | |
167 store_name = gaim_url_encode(store_name); | |
168 else | |
169 store_name = msn_user_get_passport(user); | |
9193 | 170 |
10533 | 171 /* this might be a bit of a hack, but it should prevent notification server |
172 * disconnections for people who have buddies with insane friendly names | |
173 * who added you to their buddy list from being disconnected. Stu. */ | |
174 /* Shx: What? Isn't the store_name obtained from the server, and hence it's | |
175 * below the BUDDY_ALIAS_MAXLEN ? */ | |
176 /* Stu: yeah, that's why it's a bit of a hack, as you pointed out, we're | |
177 * probably decoding the incoming store_name wrong, or something. bleh. */ | |
178 | |
179 if (strlen(store_name) > BUDDY_ALIAS_MAXLEN) | |
180 store_name = msn_user_get_passport(user); | |
181 | |
182 return store_name; | |
9193 | 183 } |
184 | |
185 static void | |
186 msn_request_add_group(MsnUserList *userlist, const char *who, | |
187 const char *old_group_name, const char *new_group_name) | |
188 { | |
189 MsnCmdProc *cmdproc; | |
19786 | 190 // MsnTransaction *trans; |
9218 | 191 MsnMoveBuddy *data; |
9193 | 192 |
193 cmdproc = userlist->session->notification->cmdproc; | |
9218 | 194 data = g_new0(MsnMoveBuddy, 1); |
9193 | 195 |
196 data->who = g_strdup(who); | |
197 | |
198 if (old_group_name) | |
199 data->old_group_name = g_strdup(old_group_name); | |
200 | |
19785 | 201 /*TODO:add new group via SOAP action*/ |
9193 | 202 } |
203 | |
204 /************************************************************************** | |
205 * Server functions | |
206 **************************************************************************/ | |
207 | |
208 MsnListId | |
209 msn_get_list_id(const char *list) | |
210 { | |
211 if (list[0] == 'F') | |
212 return MSN_LIST_FL; | |
213 else if (list[0] == 'A') | |
214 return MSN_LIST_AL; | |
215 else if (list[0] == 'B') | |
216 return MSN_LIST_BL; | |
217 else if (list[0] == 'R') | |
218 return MSN_LIST_RL; | |
219 | |
220 return -1; | |
221 } | |
222 | |
223 void | |
224 msn_got_add_user(MsnSession *session, MsnUser *user, | |
19785 | 225 MsnListId list_id, const char * group_id) |
9193 | 226 { |
227 GaimAccount *account; | |
228 const char *passport; | |
229 const char *friendly; | |
230 | |
231 account = session->account; | |
232 | |
233 passport = msn_user_get_passport(user); | |
234 friendly = msn_user_get_friendly_name(user); | |
9197
ec417d2f9666
[gaim-migrate @ 9992]
Christian Hammond <chipx86@chipx86.com>
parents:
9196
diff
changeset
|
235 |
9193 | 236 if (list_id == MSN_LIST_FL) |
237 { | |
9861 | 238 GaimConnection *gc; |
239 | |
240 gc = gaim_account_get_connection(account); | |
9193 | 241 |
242 serv_got_alias(gc, passport, friendly); | |
243 | |
19785 | 244 if (group_id != NULL) |
9193 | 245 { |
246 msn_user_add_group_id(user, group_id); | |
19785 | 247 }else{ |
9193 | 248 /* session->sync->fl_users_count++; */ |
249 } | |
19785 | 250 }else if (list_id == MSN_LIST_AL){ |
9193 | 251 gaim_privacy_permit_add(account, passport, TRUE); |
19785 | 252 }else if (list_id == MSN_LIST_BL){ |
9193 | 253 gaim_privacy_deny_add(account, passport, TRUE); |
19785 | 254 }else if (list_id == MSN_LIST_RL){ |
9861 | 255 GaimConnection *gc; |
11039
34d2aac7b34f
[gaim-migrate @ 12938]
Richard Laager <rlaager@wiktel.com>
parents:
10774
diff
changeset
|
256 GaimConversation *convo; |
9861 | 257 |
258 gc = gaim_account_get_connection(account); | |
9193 | 259 |
260 gaim_debug_info("msn", | |
12318
e346a085bb4f
[gaim-migrate @ 14622]
Richard Laager <rlaager@wiktel.com>
parents:
11638
diff
changeset
|
261 "%s has added you to his or her buddy list.\n", |
9193 | 262 passport); |
263 | |
11338 | 264 convo = gaim_find_conversation_with_account(GAIM_CONV_TYPE_IM, passport, account); |
11039
34d2aac7b34f
[gaim-migrate @ 12938]
Richard Laager <rlaager@wiktel.com>
parents:
10774
diff
changeset
|
265 if (convo) { |
34d2aac7b34f
[gaim-migrate @ 12938]
Richard Laager <rlaager@wiktel.com>
parents:
10774
diff
changeset
|
266 GaimBuddy *buddy; |
34d2aac7b34f
[gaim-migrate @ 12938]
Richard Laager <rlaager@wiktel.com>
parents:
10774
diff
changeset
|
267 char *msg; |
34d2aac7b34f
[gaim-migrate @ 12938]
Richard Laager <rlaager@wiktel.com>
parents:
10774
diff
changeset
|
268 |
34d2aac7b34f
[gaim-migrate @ 12938]
Richard Laager <rlaager@wiktel.com>
parents:
10774
diff
changeset
|
269 buddy = gaim_find_buddy(account, passport); |
34d2aac7b34f
[gaim-migrate @ 12938]
Richard Laager <rlaager@wiktel.com>
parents:
10774
diff
changeset
|
270 msg = g_strdup_printf( |
12318
e346a085bb4f
[gaim-migrate @ 14622]
Richard Laager <rlaager@wiktel.com>
parents:
11638
diff
changeset
|
271 _("%s has added you to his or her buddy list."), |
11039
34d2aac7b34f
[gaim-migrate @ 12938]
Richard Laager <rlaager@wiktel.com>
parents:
10774
diff
changeset
|
272 buddy ? gaim_buddy_get_contact_alias(buddy) : passport); |
34d2aac7b34f
[gaim-migrate @ 12938]
Richard Laager <rlaager@wiktel.com>
parents:
10774
diff
changeset
|
273 gaim_conv_im_write(GAIM_CONV_IM(convo), passport, msg, |
34d2aac7b34f
[gaim-migrate @ 12938]
Richard Laager <rlaager@wiktel.com>
parents:
10774
diff
changeset
|
274 GAIM_MESSAGE_SYSTEM, time(NULL)); |
34d2aac7b34f
[gaim-migrate @ 12938]
Richard Laager <rlaager@wiktel.com>
parents:
10774
diff
changeset
|
275 g_free(msg); |
34d2aac7b34f
[gaim-migrate @ 12938]
Richard Laager <rlaager@wiktel.com>
parents:
10774
diff
changeset
|
276 } |
34d2aac7b34f
[gaim-migrate @ 12938]
Richard Laager <rlaager@wiktel.com>
parents:
10774
diff
changeset
|
277 |
19785 | 278 if (!(user->list_op & (MSN_LIST_AL_OP | MSN_LIST_BL_OP))){ |
13827 | 279 /* |
280 * TODO: The friendly name was NULL for me when I | |
281 * looked at this. Maybe we should use the store | |
282 * name instead? --KingAnt | |
283 */ | |
9193 | 284 got_new_entry(gc, passport, friendly); |
9223
f46154d6de2b
[gaim-migrate @ 10019]
Christian Hammond <chipx86@chipx86.com>
parents:
9218
diff
changeset
|
285 } |
9193 | 286 } |
287 | |
288 user->list_op |= (1 << list_id); | |
289 /* gaim_user_add_list_id (user, list_id); */ | |
290 } | |
291 | |
292 void | |
293 msn_got_rem_user(MsnSession *session, MsnUser *user, | |
19785 | 294 MsnListId list_id, const char * group_id) |
9193 | 295 { |
296 GaimAccount *account; | |
297 const char *passport; | |
298 | |
299 account = session->account; | |
300 | |
301 passport = msn_user_get_passport(user); | |
302 | |
19786 | 303 if (list_id == MSN_LIST_FL){ |
9193 | 304 /* TODO: When is the user totally removed? */ |
19786 | 305 if (group_id != NULL){ |
9193 | 306 msn_user_remove_group_id(user, group_id); |
307 return; | |
19786 | 308 }else{ |
9193 | 309 /* session->sync->fl_users_count--; */ |
310 } | |
19786 | 311 }else if (list_id == MSN_LIST_AL){ |
9193 | 312 gaim_privacy_permit_remove(account, passport, TRUE); |
19786 | 313 }else if (list_id == MSN_LIST_BL){ |
9193 | 314 gaim_privacy_deny_remove(account, passport, TRUE); |
19786 | 315 }else if (list_id == MSN_LIST_RL){ |
11039
34d2aac7b34f
[gaim-migrate @ 12938]
Richard Laager <rlaager@wiktel.com>
parents:
10774
diff
changeset
|
316 GaimConversation *convo; |
34d2aac7b34f
[gaim-migrate @ 12938]
Richard Laager <rlaager@wiktel.com>
parents:
10774
diff
changeset
|
317 |
9193 | 318 gaim_debug_info("msn", |
12318
e346a085bb4f
[gaim-migrate @ 14622]
Richard Laager <rlaager@wiktel.com>
parents:
11638
diff
changeset
|
319 "%s has removed you from his or her buddy list.\n", |
9193 | 320 passport); |
11039
34d2aac7b34f
[gaim-migrate @ 12938]
Richard Laager <rlaager@wiktel.com>
parents:
10774
diff
changeset
|
321 |
11338 | 322 convo = gaim_find_conversation_with_account(GAIM_CONV_TYPE_IM, passport, account); |
11039
34d2aac7b34f
[gaim-migrate @ 12938]
Richard Laager <rlaager@wiktel.com>
parents:
10774
diff
changeset
|
323 if (convo) { |
34d2aac7b34f
[gaim-migrate @ 12938]
Richard Laager <rlaager@wiktel.com>
parents:
10774
diff
changeset
|
324 GaimBuddy *buddy; |
34d2aac7b34f
[gaim-migrate @ 12938]
Richard Laager <rlaager@wiktel.com>
parents:
10774
diff
changeset
|
325 char *msg; |
34d2aac7b34f
[gaim-migrate @ 12938]
Richard Laager <rlaager@wiktel.com>
parents:
10774
diff
changeset
|
326 |
34d2aac7b34f
[gaim-migrate @ 12938]
Richard Laager <rlaager@wiktel.com>
parents:
10774
diff
changeset
|
327 buddy = gaim_find_buddy(account, passport); |
34d2aac7b34f
[gaim-migrate @ 12938]
Richard Laager <rlaager@wiktel.com>
parents:
10774
diff
changeset
|
328 msg = g_strdup_printf( |
12318
e346a085bb4f
[gaim-migrate @ 14622]
Richard Laager <rlaager@wiktel.com>
parents:
11638
diff
changeset
|
329 _("%s has removed you from his or her buddy list."), |
11039
34d2aac7b34f
[gaim-migrate @ 12938]
Richard Laager <rlaager@wiktel.com>
parents:
10774
diff
changeset
|
330 buddy ? gaim_buddy_get_contact_alias(buddy) : passport); |
34d2aac7b34f
[gaim-migrate @ 12938]
Richard Laager <rlaager@wiktel.com>
parents:
10774
diff
changeset
|
331 gaim_conv_im_write(GAIM_CONV_IM(convo), passport, msg, |
34d2aac7b34f
[gaim-migrate @ 12938]
Richard Laager <rlaager@wiktel.com>
parents:
10774
diff
changeset
|
332 GAIM_MESSAGE_SYSTEM, time(NULL)); |
34d2aac7b34f
[gaim-migrate @ 12938]
Richard Laager <rlaager@wiktel.com>
parents:
10774
diff
changeset
|
333 g_free(msg); |
34d2aac7b34f
[gaim-migrate @ 12938]
Richard Laager <rlaager@wiktel.com>
parents:
10774
diff
changeset
|
334 } |
9193 | 335 } |
336 | |
337 user->list_op &= ~(1 << list_id); | |
338 /* gaim_user_remove_list_id (user, list_id); */ | |
339 | |
19786 | 340 if (user->list_op == 0){ |
9193 | 341 gaim_debug_info("msn", "Buddy '%s' shall be deleted?.\n", |
342 passport); | |
343 } | |
344 } | |
345 | |
346 void | |
347 msn_got_lst_user(MsnSession *session, MsnUser *user, | |
348 int list_op, GSList *group_ids) | |
349 { | |
350 GaimConnection *gc; | |
351 GaimAccount *account; | |
352 const char *passport; | |
353 const char *store; | |
354 | |
355 account = session->account; | |
356 gc = gaim_account_get_connection(account); | |
357 | |
358 passport = msn_user_get_passport(user); | |
9211
74c81f56b0a5
[gaim-migrate @ 10006]
Christian Hammond <chipx86@chipx86.com>
parents:
9210
diff
changeset
|
359 store = msn_user_get_store_name(user); |
9193 | 360 |
19786 | 361 if (list_op & MSN_LIST_FL_OP){ |
9193 | 362 GSList *c; |
19786 | 363 for (c = group_ids; c != NULL; c = g_slist_next(c)) { |
364 char *group_id; | |
365 group_id = c->data; | |
9193 | 366 msn_user_add_group_id(user, group_id); |
367 } | |
368 | |
369 /* FIXME: It might be a real alias */ | |
13448 | 370 /* Umm, what? This might fix bug #1385130 */ |
371 serv_got_alias(gc, passport, store); | |
9193 | 372 } |
373 | |
19785 | 374 if (list_op & MSN_LIST_AL_OP){ |
9193 | 375 /* These are users who are allowed to see our status. */ |
13692
ea77ce998dc7
[gaim-migrate @ 16095]
Richard Laager <rlaager@wiktel.com>
parents:
13448
diff
changeset
|
376 gaim_privacy_deny_remove(account, passport, TRUE); |
9193 | 377 gaim_privacy_permit_add(account, passport, TRUE); |
378 } | |
379 | |
19785 | 380 if (list_op & MSN_LIST_BL_OP){ |
9193 | 381 /* These are users who are not allowed to see our status. */ |
13692
ea77ce998dc7
[gaim-migrate @ 16095]
Richard Laager <rlaager@wiktel.com>
parents:
13448
diff
changeset
|
382 gaim_privacy_permit_remove(account, passport, TRUE); |
9193 | 383 gaim_privacy_deny_add(account, passport, TRUE); |
384 } | |
385 | |
19785 | 386 if (list_op & MSN_LIST_RL_OP){ |
12318
e346a085bb4f
[gaim-migrate @ 14622]
Richard Laager <rlaager@wiktel.com>
parents:
11638
diff
changeset
|
387 /* These are users who have us on their buddy list. */ |
13827 | 388 /* |
389 * TODO: What is store name set to when this happens? | |
390 * For one of my accounts "something@hotmail.com" | |
391 * the store name was "something." Maybe we | |
392 * should use the friendly name, instead? --KingAnt | |
393 */ | |
9193 | 394 |
19785 | 395 if (!(list_op & (MSN_LIST_AL_OP | MSN_LIST_BL_OP))){ |
9193 | 396 got_new_entry(gc, passport, store); |
9225
554ef91db2dd
[gaim-migrate @ 10021]
Christian Hammond <chipx86@chipx86.com>
parents:
9223
diff
changeset
|
397 } |
9193 | 398 } |
399 | |
19785 | 400 user->list_op |= list_op; |
9193 | 401 } |
402 | |
403 /************************************************************************** | |
404 * UserList functions | |
405 **************************************************************************/ | |
406 | |
407 MsnUserList* | |
408 msn_userlist_new(MsnSession *session) | |
409 { | |
410 MsnUserList *userlist; | |
9198
ab6636c5a136
[gaim-migrate @ 9993]
Christian Hammond <chipx86@chipx86.com>
parents:
9197
diff
changeset
|
411 |
9193 | 412 userlist = g_new0(MsnUserList, 1); |
413 | |
414 userlist->session = session; | |
9860 | 415 userlist->buddy_icon_requests = g_queue_new(); |
13125 | 416 |
417 /* buddy_icon_window is the number of allowed simultaneous buddy icon requests. | |
418 * XXX With smarter rate limiting code, we could allow more at once... 5 was the limit set when | |
419 * we weren't retrieiving any more than 5 per MSN session. */ | |
420 userlist->buddy_icon_window = 1; | |
9193 | 421 |
422 return userlist; | |
423 } | |
424 | |
425 void | |
426 msn_userlist_destroy(MsnUserList *userlist) | |
427 { | |
428 GList *l; | |
429 | |
19785 | 430 /*destroy userlist*/ |
431 for (l = userlist->users; l != NULL; l = l->next){ | |
9193 | 432 msn_user_destroy(l->data); |
433 } | |
434 g_list_free(userlist->users); | |
435 | |
19785 | 436 /*destroy group list*/ |
437 for (l = userlist->groups; l != NULL; l = l->next){ | |
9193 | 438 msn_group_destroy(l->data); |
439 } | |
440 g_list_free(userlist->groups); | |
9895 | 441 |
442 g_queue_free(userlist->buddy_icon_requests); | |
13125 | 443 |
444 if (userlist->buddy_icon_request_timer) | |
445 gaim_timeout_remove(userlist->buddy_icon_request_timer); | |
446 | |
9857 | 447 g_free(userlist); |
9193 | 448 } |
449 | |
450 void | |
451 msn_userlist_add_user(MsnUserList *userlist, MsnUser *user) | |
452 { | |
453 userlist->users = g_list_append(userlist->users, user); | |
454 } | |
455 | |
456 void | |
457 msn_userlist_remove_user(MsnUserList *userlist, MsnUser *user) | |
458 { | |
459 userlist->users = g_list_remove(userlist->users, user); | |
460 } | |
461 | |
462 MsnUser * | |
463 msn_userlist_find_user(MsnUserList *userlist, const char *passport) | |
464 { | |
465 GList *l; | |
466 | |
467 g_return_val_if_fail(passport != NULL, NULL); | |
468 | |
19785 | 469 for (l = userlist->users; l != NULL; l = l->next){ |
9193 | 470 MsnUser *user = (MsnUser *)l->data; |
19787 | 471 // gaim_debug_info("MsnUserList","user passport:%s,passport:%s\n",user->passport,passport); |
9193 | 472 g_return_val_if_fail(user->passport != NULL, NULL); |
473 | |
19787 | 474 if (!g_strcasecmp(passport, user->passport)){ |
475 // gaim_debug_info("MsnUserList","return:%p\n",user); | |
9193 | 476 return user; |
19787 | 477 } |
9193 | 478 } |
479 | |
480 return NULL; | |
481 } | |
482 | |
483 void | |
484 msn_userlist_add_group(MsnUserList *userlist, MsnGroup *group) | |
485 { | |
486 userlist->groups = g_list_append(userlist->groups, group); | |
487 } | |
488 | |
489 void | |
490 msn_userlist_remove_group(MsnUserList *userlist, MsnGroup *group) | |
491 { | |
492 userlist->groups = g_list_remove(userlist->groups, group); | |
493 } | |
494 | |
495 MsnGroup * | |
19785 | 496 msn_userlist_find_group_with_id(MsnUserList *userlist, const char * id) |
9193 | 497 { |
498 GList *l; | |
499 | |
500 g_return_val_if_fail(userlist != NULL, NULL); | |
19785 | 501 g_return_val_if_fail(id != NULL, NULL); |
9193 | 502 |
19785 | 503 for (l = userlist->groups; l != NULL; l = l->next){ |
9193 | 504 MsnGroup *group = l->data; |
505 | |
19786 | 506 if (!g_strcasecmp(group->id,id)) |
9193 | 507 return group; |
508 } | |
509 | |
510 return NULL; | |
511 } | |
512 | |
513 MsnGroup * | |
514 msn_userlist_find_group_with_name(MsnUserList *userlist, const char *name) | |
515 { | |
516 GList *l; | |
517 | |
518 g_return_val_if_fail(userlist != NULL, NULL); | |
519 g_return_val_if_fail(name != NULL, NULL); | |
520 | |
19787 | 521 for (l = userlist->groups; l != NULL; l = l->next){ |
9193 | 522 MsnGroup *group = l->data; |
523 | |
19787 | 524 if ((group->name != NULL) && !g_strcasecmp(name, group->name)) |
9193 | 525 return group; |
526 } | |
527 | |
528 return NULL; | |
529 } | |
530 | |
19785 | 531 const char * |
9193 | 532 msn_userlist_find_group_id(MsnUserList *userlist, const char *group_name) |
533 { | |
534 MsnGroup *group; | |
9198
ab6636c5a136
[gaim-migrate @ 9993]
Christian Hammond <chipx86@chipx86.com>
parents:
9197
diff
changeset
|
535 |
9193 | 536 group = msn_userlist_find_group_with_name(userlist, group_name); |
537 | |
19786 | 538 if (group != NULL){ |
9193 | 539 return msn_group_get_id(group); |
19786 | 540 }else{ |
19785 | 541 return NULL; |
19786 | 542 } |
9193 | 543 } |
544 | |
545 const char * | |
19785 | 546 msn_userlist_find_group_name(MsnUserList *userlist, const char * group_id) |
9193 | 547 { |
548 MsnGroup *group; | |
9198
ab6636c5a136
[gaim-migrate @ 9993]
Christian Hammond <chipx86@chipx86.com>
parents:
9197
diff
changeset
|
549 |
9193 | 550 group = msn_userlist_find_group_with_id(userlist, group_id); |
551 | |
19785 | 552 if (group != NULL){ |
9193 | 553 return msn_group_get_name(group); |
19785 | 554 }else{ |
9193 | 555 return NULL; |
19785 | 556 } |
9193 | 557 } |
558 | |
559 void | |
19785 | 560 msn_userlist_rename_group_id(MsnUserList *userlist, const char * group_id, |
9193 | 561 const char *new_name) |
562 { | |
563 MsnGroup *group; | |
564 | |
565 group = msn_userlist_find_group_with_id(userlist, group_id); | |
566 | |
567 if (group != NULL) | |
568 msn_group_set_name(group, new_name); | |
569 } | |
570 | |
571 void | |
19785 | 572 msn_userlist_remove_group_id(MsnUserList *userlist, const char * group_id) |
9193 | 573 { |
574 MsnGroup *group; | |
575 | |
576 group = msn_userlist_find_group_with_id(userlist, group_id); | |
577 | |
578 if (group != NULL) | |
10533 | 579 { |
9193 | 580 msn_userlist_remove_group(userlist, group); |
10533 | 581 msn_group_destroy(group); |
582 } | |
9193 | 583 } |
584 | |
585 void | |
586 msn_userlist_rem_buddy(MsnUserList *userlist, | |
587 const char *who, int list_id, const char *group_name) | |
588 { | |
589 MsnUser *user; | |
19786 | 590 const char *group_id; |
9193 | 591 const char *list; |
592 | |
593 user = msn_userlist_find_user(userlist, who); | |
19785 | 594 group_id = NULL; |
9193 | 595 |
19785 | 596 if (group_name != NULL){ |
9193 | 597 group_id = msn_userlist_find_group_id(userlist, group_name); |
598 | |
19785 | 599 if (group_id == NULL){ |
9193 | 600 /* Whoa, there is no such group. */ |
601 gaim_debug_error("msn", "Group doesn't exist: %s\n", group_name); | |
602 return; | |
603 } | |
604 } | |
605 | |
606 /* First we're going to check if not there. */ | |
19785 | 607 if (!(user_is_there(user, list_id, group_id))){ |
9193 | 608 list = lists[list_id]; |
609 gaim_debug_error("msn", "User '%s' is not there: %s\n", | |
610 who, list); | |
611 return; | |
612 } | |
613 | |
614 /* Then request the rem to the server. */ | |
615 list = lists[list_id]; | |
616 | |
617 msn_notification_rem_buddy(userlist->session->notification, list, who, group_id); | |
618 } | |
619 | |
19791 | 620 /*add buddy*/ |
9193 | 621 void |
622 msn_userlist_add_buddy(MsnUserList *userlist, | |
623 const char *who, int list_id, | |
624 const char *group_name) | |
625 { | |
626 MsnUser *user; | |
19786 | 627 const char *group_id; |
9193 | 628 const char *list; |
629 const char *store_name; | |
9194
364aa73323b5
[gaim-migrate @ 9989]
Christian Hammond <chipx86@chipx86.com>
parents:
9193
diff
changeset
|
630 |
19786 | 631 group_id = NULL; |
9193 | 632 |
19785 | 633 if (!gaim_email_is_valid(who)){ |
11638 | 634 /* only notify the user about problems adding to the friends list |
635 * maybe we should do something else for other lists, but it probably | |
636 * won't cause too many problems if we just ignore it */ | |
19785 | 637 if (list_id == MSN_LIST_FL) { |
11638 | 638 char *str = g_strdup_printf(_("Unable to add \"%s\"."), who); |
639 gaim_notify_error(NULL, NULL, str, | |
640 _("The screen name specified is invalid.")); | |
641 g_free(str); | |
642 } | |
643 | |
11057
e9eeacd1a8d0
[gaim-migrate @ 13009]
Richard Laager <rlaager@wiktel.com>
parents:
11039
diff
changeset
|
644 return; |
e9eeacd1a8d0
[gaim-migrate @ 13009]
Richard Laager <rlaager@wiktel.com>
parents:
11039
diff
changeset
|
645 } |
e9eeacd1a8d0
[gaim-migrate @ 13009]
Richard Laager <rlaager@wiktel.com>
parents:
11039
diff
changeset
|
646 |
19785 | 647 if (group_name != NULL){ |
9193 | 648 group_id = msn_userlist_find_group_id(userlist, group_name); |
649 | |
19786 | 650 if (group_id == NULL){ |
9193 | 651 /* Whoa, we must add that group first. */ |
652 msn_request_add_group(userlist, who, NULL, group_name); | |
653 return; | |
654 } | |
655 } | |
656 | |
657 user = msn_userlist_find_user(userlist, who); | |
658 | |
9194
364aa73323b5
[gaim-migrate @ 9989]
Christian Hammond <chipx86@chipx86.com>
parents:
9193
diff
changeset
|
659 /* First we're going to check if it's already there. */ |
19785 | 660 if (user_is_there(user, list_id, group_id)){ |
9193 | 661 list = lists[list_id]; |
9194
364aa73323b5
[gaim-migrate @ 9989]
Christian Hammond <chipx86@chipx86.com>
parents:
9193
diff
changeset
|
662 gaim_debug_error("msn", "User '%s' is already there: %s\n", who, list); |
9193 | 663 return; |
664 } | |
665 | |
666 store_name = (user != NULL) ? get_store_name(user) : who; | |
667 | |
668 /* Then request the add to the server. */ | |
669 list = lists[list_id]; | |
670 | |
671 msn_notification_add_buddy(userlist->session->notification, list, who, | |
672 store_name, group_id); | |
673 } | |
674 | |
675 void | |
676 msn_userlist_move_buddy(MsnUserList *userlist, const char *who, | |
677 const char *old_group_name, const char *new_group_name) | |
678 { | |
19786 | 679 const char *new_group_id; |
9193 | 680 |
681 new_group_id = msn_userlist_find_group_id(userlist, new_group_name); | |
682 | |
19786 | 683 if (new_group_id == NULL){ |
9193 | 684 msn_request_add_group(userlist, who, old_group_name, new_group_name); |
685 return; | |
686 } | |
687 | |
10568 | 688 msn_userlist_add_buddy(userlist, who, MSN_LIST_FL, new_group_name); |
9193 | 689 msn_userlist_rem_buddy(userlist, who, MSN_LIST_FL, old_group_name); |
690 } | |
19785 | 691 |