Mercurial > pidgin.yaz
annotate src/protocols/yahoo/yahoo_profile.c @ 11985:41d84ac57cb6
[gaim-migrate @ 14278]
Getting some stuff out of my tree
committer: Tailor Script <tailor@pidgin.im>
author | Mark Doliner <mark@kingant.net> |
---|---|
date | Sat, 05 Nov 2005 21:49:44 +0000 |
parents | 52f27ffe68a5 |
children | df93ed932b3a |
rev | line source |
---|---|
9162 | 1 /* |
2 * gaim | |
3 * | |
4 * Gaim is the legal property of its developers, whose names are too numerous | |
5 * to list here. Please refer to the COPYRIGHT file distributed with this | |
6 * source distribution. | |
7 * | |
8 * This program is free software; you can redistribute it and/or modify | |
9 * it under the terms of the GNU General Public License as published by | |
10 * the Free Software Foundation; either version 2 of the License, or | |
11 * (at your option) any later version. | |
12 * | |
13 * This program is distributed in the hope that it will be useful, | |
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of | |
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
16 * GNU General Public License for more details. | |
17 * | |
18 * You should have received a copy of the GNU General Public License | |
19 * along with this program; if not, write to the Free Software | |
20 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | |
21 * | |
22 */ | |
23 | |
9242 | 24 #define PHOTO_SUPPORT 1 |
25 | |
9162 | 26 #include "internal.h" |
27 #include "debug.h" | |
28 #include "notify.h" | |
29 #include "util.h" | |
9242 | 30 #if PHOTO_SUPPORT |
31 #include "imgstore.h" | |
32 #endif | |
9162 | 33 |
34 #include "yahoo.h" | |
9281 | 35 #include "yahoo_friend.h" |
9162 | 36 |
37 typedef struct { | |
38 GaimConnection *gc; | |
39 char *name; | |
40 } YahooGetInfoData; | |
41 | |
42 typedef enum profile_lang_id { | |
43 XX, DA, DE, EL, | |
44 EN, EN_GB, | |
45 ES_AR, ES_ES, ES_MX, ES_US, | |
46 FR_CA, FR_FR, | |
47 IT, JA, KO, NO, PT, SV, | |
48 ZH_CN, ZH_HK, ZH_TW, ZH_US | |
49 } profile_lang_id_t; | |
50 | |
51 typedef struct profile_lang_node { | |
52 profile_lang_id_t lang; | |
53 char *last_updated_string; | |
54 char *det; | |
55 } profile_lang_node_t; | |
56 | |
57 typedef struct profile_strings_node { | |
58 profile_lang_id_t lang; | |
59 char *lang_string; /* Only to make debugging output saner */ | |
60 char *charset; | |
61 char *yahoo_id_string; | |
62 char *private_string; | |
63 char *no_answer_string; | |
64 char *my_email_string; | |
65 char *realname_string; | |
66 char *location_string; | |
67 char *age_string; | |
68 char *maritalstatus_string; | |
69 char *gender_string; | |
70 char *occupation_string; | |
71 char *hobbies_string; | |
72 char *latest_news_string; | |
73 char *favorite_quote_string; | |
74 char *links_string; | |
75 char *no_home_page_specified_string; | |
76 char *home_page_string; | |
77 char *no_cool_link_specified_string; | |
78 char *cool_link_1_string; | |
79 char *cool_link_2_string; | |
80 char *cool_link_3_string; | |
81 char *dummy; | |
82 } profile_strings_node_t; | |
83 | |
9510 | 84 typedef enum profile_state { |
85 PROFILE_STATE_DEFAULT, | |
86 PROFILE_STATE_NOT_FOUND, | |
87 PROFILE_STATE_UNKNOWN_LANGUAGE | |
88 } profile_state_t; | |
89 | |
9242 | 90 typedef struct { |
91 YahooGetInfoData *info_data; | |
92 char *url_buffer; | |
93 GString *s; | |
94 char *photo_url_text; | |
95 char *profile_url_text; | |
96 char *tooltip_text; | |
97 const profile_strings_node_t *strings; | |
98 const char *last_updated_string; | |
9510 | 99 const char *title; |
100 profile_state_t profile_state; | |
9242 | 101 } YahooGetInfoStepTwoData; |
102 | |
9162 | 103 /* Strings to determine the profile "language" (more accurately "locale"). |
104 * Strings in this list must be in the original charset in the profile. | |
105 * The "Last Updated" string is used, but sometimes is not sufficient to | |
106 * distinguish 2 locales with this (e.g., ES_ES from ES_US, or FR_CA from | |
107 * FR_FR, or EL from EN_GB), in which case a second string is added and | |
108 * such special cases must be placed before the more general case. | |
109 */ | |
110 static const profile_lang_node_t profile_langs[] = { | |
111 { DA, "Opdateret sidste gang ", NULL }, | |
112 { DE, "Letzter Update ", NULL }, | |
113 { EL, "Last Updated:", "http://gr.profiles.yahoo.com" }, | |
11045
d456fdaf6c73
[gaim-migrate @ 12961]
Richard Laager <rlaager@wiktel.com>
parents:
10604
diff
changeset
|
114 { EN_GB, "Last Update ", "Favourite Quote" }, |
d456fdaf6c73
[gaim-migrate @ 12961]
Richard Laager <rlaager@wiktel.com>
parents:
10604
diff
changeset
|
115 { EN, "Last Update:", NULL }, |
d456fdaf6c73
[gaim-migrate @ 12961]
Richard Laager <rlaager@wiktel.com>
parents:
10604
diff
changeset
|
116 { EN, "Last Update ", NULL }, |
9162 | 117 { ES_AR, "\332ltima actualizaci\363n ", NULL }, |
118 { ES_ES, "Actualizada el ", "http://es.profiles.yahoo.com" }, | |
119 { ES_MX, "Actualizada el ", "http://mx.profiles.yahoo.com" }, | |
120 { ES_US, "Actualizada el ", NULL }, | |
121 { FR_CA, "Derni\xe8re mise \xe0 jour", "http://cf.profiles.yahoo.com" }, | |
122 { FR_FR, "Derni\xe8re mise \xe0 jour", NULL }, | |
11626 | 123 { IT, "Ultimo aggiornamento:", NULL }, |
9162 | 124 { JA, "\xba\xc7\xbd\xaa\xb9\xb9\xbf\xb7\xc6\xfc\xa1\xa7", NULL }, |
125 { KO, "\xb0\xbb\xbd\xc5\x20\xb3\xaf\xc2\xa5 ", NULL }, | |
126 { NO, "Sist oppdatert ", NULL }, | |
127 { PT, "\332ltima atualiza\347\343o ", NULL }, | |
128 { SV, "Senast uppdaterad ", NULL }, | |
129 { ZH_CN, "\xd7\xee\xba\xf3\xd0\xde\xb8\xc4\xc8\xd5\xc6\xda", NULL }, | |
130 { ZH_HK, "\xb3\xcc\xaa\xf1\xa7\xf3\xb7\x73\xae\xc9\xb6\xa1", NULL }, | |
131 { ZH_US, "\xb3\xcc\xab\xe1\xad\xd7\xa7\xef\xa4\xe9\xb4\xc1", "http://chinese.profiles.yahoo.com" }, | |
132 { ZH_TW, "\xb3\xcc\xab\xe1\xad\xd7\xa7\xef\xa4\xe9\xb4\xc1", NULL }, | |
133 { XX, NULL, NULL } | |
134 }; | |
135 | |
136 /* Strings in this list must be in UTF-8; 's should be specified as spaces. */ | |
137 static const profile_strings_node_t profile_strings[] = { | |
138 { DA, "da", "ISO-8859-1", | |
139 "Yahoo! ID:", | |
140 "Privat", | |
141 "Intet svar", | |
142 "Min Email", | |
143 "Rigtige navn:", | |
144 "Opholdssted:", | |
145 "Alder:", | |
146 "Ægteskabelig status:", | |
147 "Køn:", | |
148 "Erhverv:", | |
149 "Hobbyer:", | |
150 "Sidste nyt:", | |
151 "Favoritcitat", | |
152 "Links", | |
153 "Ingen hjemmeside specificeret", | |
154 "Forside:", | |
155 "Intet cool link specificeret", | |
156 "Cool link 1:", | |
157 "Cool link 2:", | |
158 "Cool link 3:", | |
159 NULL | |
160 }, | |
161 { DE, "de", "ISO-8859-1", | |
162 "Yahoo!-ID:", | |
163 "Privat", | |
164 "Keine Antwort", | |
165 "Meine E-Mail", | |
166 "Realer Name:", | |
167 "Ort:", | |
168 "Alter:", | |
169 "Familienstand:", | |
170 "Geschlecht:", | |
171 "Beruf:", | |
172 "Hobbys:", | |
173 "Neuste Nachrichten:", | |
174 "Mein Lieblingsspruch", | |
175 "Links", | |
176 "Keine Homepage angegeben", | |
177 "Homepage:", | |
178 "Keinen coolen Link angegeben", | |
179 "Cooler Link 1:", | |
180 "Cooler Link 2:", | |
181 "Cooler Link 3:", | |
182 NULL | |
183 }, | |
184 { EL, "el", "ISO-8859-7", /* EL is identical to EN, except no_answer_string */ | |
185 "Yahoo! ID:", | |
186 "Private", | |
187 "Καμία απάντηση", | |
188 "My Email", | |
189 "Real Name:", | |
190 "Location:", | |
191 "Age:", | |
192 "Marital Status:", | |
193 "Gender:", | |
194 "Occupation:", | |
195 "Hobbies:", | |
196 "Latest News", | |
197 "Favorite Quote", | |
198 "Links", | |
199 "No home page specified", | |
200 "Home Page:", | |
201 "No cool link specified", | |
202 "Cool Link 1:", | |
203 "Cool Link 2:", | |
204 "Cool Link 3:", | |
205 NULL | |
206 }, | |
207 { EN, "en", "ISO-8859-1", | |
208 "Yahoo! ID:", | |
209 "Private", | |
210 "No Answer", | |
11045
d456fdaf6c73
[gaim-migrate @ 12961]
Richard Laager <rlaager@wiktel.com>
parents:
10604
diff
changeset
|
211 "My Email:", |
9162 | 212 "Real Name:", |
213 "Location:", | |
214 "Age:", | |
215 "Marital Status:", | |
11626 | 216 "Gender:", |
9162 | 217 "Occupation:", |
11045
d456fdaf6c73
[gaim-migrate @ 12961]
Richard Laager <rlaager@wiktel.com>
parents:
10604
diff
changeset
|
218 "Hobbies", |
9162 | 219 "Latest News", |
220 "Favorite Quote", | |
221 "Links", | |
222 "No home page specified", | |
223 "Home Page:", | |
224 "No cool link specified", | |
11045
d456fdaf6c73
[gaim-migrate @ 12961]
Richard Laager <rlaager@wiktel.com>
parents:
10604
diff
changeset
|
225 "Cool Link 1", |
d456fdaf6c73
[gaim-migrate @ 12961]
Richard Laager <rlaager@wiktel.com>
parents:
10604
diff
changeset
|
226 "Cool Link 2", |
d456fdaf6c73
[gaim-migrate @ 12961]
Richard Laager <rlaager@wiktel.com>
parents:
10604
diff
changeset
|
227 "Cool Link 3", |
9162 | 228 NULL |
229 }, | |
230 { EN_GB, "en_GB", "ISO-8859-1", /* Same as EN except spelling of "Favourite" */ | |
231 "Yahoo! ID:", | |
232 "Private", | |
233 "No Answer", | |
11045
d456fdaf6c73
[gaim-migrate @ 12961]
Richard Laager <rlaager@wiktel.com>
parents:
10604
diff
changeset
|
234 "My Email:", |
9162 | 235 "Real Name:", |
236 "Location:", | |
237 "Age:", | |
238 "Marital Status:", | |
11626 | 239 "Gender:", |
9162 | 240 "Occupation:", |
11045
d456fdaf6c73
[gaim-migrate @ 12961]
Richard Laager <rlaager@wiktel.com>
parents:
10604
diff
changeset
|
241 "Hobbies", |
9162 | 242 "Latest News", |
243 "Favourite Quote", | |
244 "Links", | |
245 "No home page specified", | |
246 "Home Page:", | |
247 "No cool link specified", | |
11045
d456fdaf6c73
[gaim-migrate @ 12961]
Richard Laager <rlaager@wiktel.com>
parents:
10604
diff
changeset
|
248 "Cool Link 1", |
d456fdaf6c73
[gaim-migrate @ 12961]
Richard Laager <rlaager@wiktel.com>
parents:
10604
diff
changeset
|
249 "Cool Link 2", |
d456fdaf6c73
[gaim-migrate @ 12961]
Richard Laager <rlaager@wiktel.com>
parents:
10604
diff
changeset
|
250 "Cool Link 3", |
9162 | 251 NULL |
252 }, | |
253 { ES_AR, "es_AR", "ISO-8859-1", | |
254 "Usuario de Yahoo!:", | |
255 "Privado", | |
256 "No introdujiste una respuesta", | |
257 "Mi dirección de correo electrónico", | |
258 "Nombre real:", | |
259 "Ubicación:", | |
260 "Edad:", | |
261 "Estado civil:", | |
262 "Sexo:", | |
263 "Ocupación:", | |
264 "Pasatiempos:", | |
265 "Últimas noticias:", | |
266 "Tu cita favorita", | |
267 "Enlaces", | |
268 "Ninguna página de inicio especificada", | |
269 "Página de inicio:", | |
270 "Ningún enlace preferido", | |
271 "Enlace genial 1:", | |
272 "Enlace genial 2:", | |
273 "Enlace genial 3:", | |
274 NULL | |
275 }, | |
276 { ES_ES, "es_ES", "ISO-8859-1", | |
277 "ID de Yahoo!:", | |
278 "Privado", | |
279 "Sin respuesta", | |
280 "Mi correo-e", | |
281 "Nombre verdadero:", | |
282 "Lugar:", | |
283 "Edad:", | |
284 "Estado civil:", | |
285 "Sexo:", | |
286 "Ocupación:", | |
287 "Aficiones:", | |
288 "Ultimas Noticias:", | |
289 "Tu cita Favorita", | |
290 "Enlace", | |
291 "Ninguna página personal especificada", | |
292 "Página de Inicio:", | |
293 "Ningún enlace preferido", | |
294 "Enlaces Preferidos 1:", | |
295 "Enlaces Preferidos 2:", | |
296 "Enlaces Preferidos 3:", | |
297 NULL | |
298 }, | |
299 { ES_MX, "es_MX", "ISO-8859-1", | |
300 "ID de Yahoo!:", | |
301 "Privado", | |
302 "Sin responder", | |
303 "Mi Dirección de correo-e", | |
304 "Nombre real:", | |
305 "Ubicación:", | |
306 "Edad:", | |
307 "Estado civil:", | |
308 "Sexo:", | |
309 "Ocupación:", | |
310 "Pasatiempos:", | |
311 "Ultimas Noticias:", | |
312 "Su cita favorita", | |
313 "Enlaces", | |
314 "Ninguna Página predefinida", | |
315 "Página web:", | |
316 "Ningún Enlace preferido", | |
317 "Enlaces Preferidos 1:", | |
318 "Enlaces Preferidos 2:", | |
319 "Enlaces Preferidos 3:", | |
320 NULL | |
321 }, | |
322 { ES_US, "es_US", "ISO-8859-1", | |
323 "ID de Yahoo!:", | |
324 "Privado", | |
325 "No introdujo una respuesta", | |
326 "Mi Dirección de correo-e", | |
327 "Nombre real:", | |
328 "Localidad:", | |
329 "Edad:", | |
330 "Estado civil:", | |
331 "Sexo:", | |
332 "Ocupación:", | |
333 "Pasatiempos:", | |
334 "Ultimas Noticias:", | |
335 "Su cita Favorita", | |
336 "Enlaces", | |
337 "Ninguna Página de inicio predefinida", | |
338 "Página de inicio:", | |
339 "Ningún Enlace preferido", | |
340 "Enlaces Preferidos 1:", | |
341 "Enlaces Preferidos 2:", | |
342 "Enlaces Preferidos 3:", | |
343 NULL | |
344 }, | |
345 { FR_CA, "fr_CA", "ISO-8859-1", | |
346 "Compte Yahoo!:", | |
347 "Privé", | |
348 "Sans réponse", | |
349 "Mon courriel", | |
350 "Nom réel:", | |
351 "Lieu:", | |
352 "Âge:", | |
353 "État civil:", | |
354 "Sexe:", | |
355 "Profession:", | |
356 "Passe-temps:", | |
357 "Actualités:", | |
358 "Citation préférée", | |
359 "Liens", | |
360 "Pas de mention d'une page personnelle", | |
361 "Page personnelle:", | |
362 "Pas de mention d'un lien favori", | |
363 "Lien préféré 1:", | |
364 "Lien préféré 2:", | |
365 "Lien préféré 3:", | |
366 NULL | |
367 }, | |
368 { FR_FR, "fr_FR", "ISO-8859-1", | |
369 "Compte Yahoo!:", | |
370 "Privé", | |
371 "Sans réponse", | |
372 "Mon E-mail", | |
373 "Nom réel:", | |
374 "Lieu:", | |
375 "Âge:", | |
376 "Situation de famille:", | |
377 "Sexe:", | |
378 "Profession:", | |
379 "Centres d'intérêts:", | |
380 "Actualités:", | |
381 "Citation préférée", | |
382 "Liens", | |
383 "Pas de mention d'une page perso", | |
384 "Page perso:", | |
385 "Pas de mention d'un lien favori", | |
386 "Lien préféré 1:", | |
387 "Lien préféré 2:", | |
388 "Lien préféré 3:", | |
389 NULL | |
390 }, | |
391 { IT, "it", "ISO-8859-1", | |
11626 | 392 "Yahoo! ID:", |
9162 | 393 "Non pubblica", |
394 "Nessuna risposta", | |
11626 | 395 "La mia e-mail:", |
9162 | 396 "Nome vero:", |
397 "Località:", | |
11626 | 398 "Età:", |
9162 | 399 "Stato civile:", |
400 "Sesso:", | |
401 "Occupazione:", | |
11626 | 402 "Hobby", |
403 "Ultime notizie", | |
9162 | 404 "Citazione preferita", |
405 "Link", | |
406 "Nessuna home page specificata", | |
407 "Inizio:", | |
408 "Nessun link specificato", | |
11626 | 409 "Cool Link 1", |
410 "Cool Link 2", | |
411 "Cool Link 3", | |
9162 | 412 NULL |
413 }, | |
414 { JA, "ja", "EUC-JP", | |
415 "Yahoo! JAPAN ID:", | |
416 "非公開", | |
417 "無回答", | |
418 "メール:", | |
419 "名前:", | |
420 "住所:", | |
421 "年齢:", | |
422 "未婚/既婚:", | |
423 "性別:", | |
424 "職業:", | |
425 "趣味:", | |
426 "最近の出来事:", | |
427 NULL, | |
428 #if 0 | |
429 "おすすめサイト", | |
430 #else | |
431 "自己PR", /* "Self description" comes before "Links" for yahoo.co.jp */ | |
432 #endif | |
433 NULL, | |
434 NULL, | |
435 NULL, | |
436 "おすすめサイト1:", | |
437 "おすすめサイト2:", | |
438 "おすすめサイト3:", | |
439 NULL | |
440 }, | |
441 { KO, "ko", "EUC-KR", | |
442 "야후! ID:", | |
443 "비공개", | |
444 "비공개", | |
445 "My Email", | |
446 "실명:", | |
447 "거주지:", | |
448 "나이:", | |
449 "결혼 여부:", | |
450 "성별:", | |
451 "직업:", | |
452 "취미:", | |
453 "자기 소개:", | |
454 "좋아하는 명언", | |
455 "링크", | |
456 "홈페이지를 지정하지 않았습니다.", | |
457 "홈페이지:", | |
458 "추천 사이트가 없습니다.", | |
459 "추천 사이트 1:", | |
460 "추천 사이트 2:", | |
461 "추천 사이트 3:", | |
462 NULL | |
463 }, | |
464 { NO, "no", "ISO-8859-1", | |
465 "Yahoo! ID:", | |
466 "Privat", | |
467 "Ikke noe svar", | |
468 "Min e-post", | |
469 "Virkelig navn:", | |
470 "Sted:", | |
471 "Alder:", | |
472 "Sivilstatus:", | |
473 "Kjønn:", | |
474 "Yrke:", | |
475 "Hobbyer:", | |
476 "Siste nytt:", | |
477 "Yndlingssitat", | |
478 "Lenker", | |
479 "Ingen hjemmeside angitt", | |
480 "Hjemmeside:", | |
481 "No cool link specified", | |
482 "Bra lenke 1:", | |
483 "Bra lenke 2:", | |
484 "Bra lenke 3:", | |
485 NULL | |
486 }, | |
487 { PT, "pt", "ISO-8859-1", | |
488 "ID Yahoo!:", | |
489 "Particular", | |
490 "Sem resposta", | |
491 "Meu e-mail", | |
492 "Nome verdadeiro:", | |
493 "Local:", | |
494 "Idade:", | |
495 "Estado civil:", | |
496 "Sexo:", | |
497 "Ocupação:", | |
498 "Hobbies:", | |
499 "Últimas notícias:", | |
500 "Frase favorita", | |
501 "Links", | |
502 "Nenhuma página pessoal especificada", | |
503 "Página pessoal:", | |
504 "Nenhum site legal especificado", | |
505 "Site legal 1:", | |
506 "Site legal 2:", | |
507 "Site legal 3:", | |
508 NULL | |
509 }, | |
510 { SV, "sv", "ISO-8859-1", | |
511 "Yahoo!-ID:", | |
512 "Privat", | |
513 "Inget svar", | |
514 "Min mail", | |
515 "Riktigt namn:", | |
516 "Plats:", | |
517 "Ålder:", | |
518 "Civilstånd:", | |
519 "Kön:", | |
520 "Yrke:", | |
521 "Hobby:", | |
522 "Senaste nytt:", | |
523 "Favoritcitat", | |
524 "Länkar", | |
525 "Ingen hemsida specificerad", | |
526 "Hemsida:", | |
527 "Ingen cool länk specificerad", | |
528 "Coola länkar 1:", | |
529 "Coola länkar 2:", | |
530 "Coola länkar 3:", | |
531 NULL | |
532 }, | |
533 { ZH_CN, "zh_CN", "GB2312", | |
534 "Yahoo! ID:", | |
535 "没有提供", | |
536 "没有回答", | |
537 "个人电邮地址", | |
538 "真实姓名:", | |
539 "所在地点:", | |
540 "年龄:", | |
541 "婚姻状况:", | |
542 "性别:", | |
543 "职业:", | |
544 "业余爱好:", | |
545 "个人近况:", | |
546 "喜欢的引言", | |
547 "链接", | |
548 "没有个人主页", | |
549 "个人主页:", | |
550 "没有推荐网站链接", | |
551 "推荐网站链接 1:", | |
552 "推荐网站链接 2:", | |
553 "推荐网站链接 3:", | |
554 NULL | |
555 }, | |
556 { ZH_HK, "zh_HK", "Big5", | |
557 "Yahoo! ID:", | |
558 "私人的", | |
559 "沒有回答", | |
560 "電子信箱", | |
561 "真實姓名:", | |
562 "地點:", | |
563 "年齡:", | |
564 "婚姻狀況:", | |
565 "性別:", | |
566 "職業:", | |
567 "嗜好:", | |
568 "最新消息:", | |
569 "最喜愛的股票叫價", /* [sic] Yahoo!'s translators don't check context */ | |
570 "連結", | |
571 "沒有注明個人網頁", /* [sic] */ | |
572 "個人網頁:", | |
573 "沒有注明 Cool 連結", /* [sic] */ | |
574 "Cool 連結 1:", /* TODO */ | |
575 "Cool 連結 2:", /* TODO */ | |
576 "Cool 連結 3:", /* TODO */ | |
577 NULL | |
578 }, | |
579 { ZH_TW, "zh_TW", "Big5", | |
580 "帳 號:", | |
581 "沒有提供", | |
582 "沒有回應", | |
583 "電子信箱", | |
584 "姓名:", | |
585 "地點:", | |
586 "年齡:", | |
587 "婚姻狀態:", | |
588 "性別:", | |
589 "職業:", | |
590 "興趣:", | |
591 "個人近況:", | |
592 "喜歡的名句", | |
593 "連結", | |
594 "沒有個人網頁", | |
595 "個人網頁:", | |
596 "沒有推薦網站連結", | |
597 "推薦網站連結 1:", | |
598 "推薦網站連結 2:", | |
599 "推薦網站連結 3:", | |
600 NULL | |
601 }, | |
602 { ZH_US, "zh_US", "Big5", /* ZH_US is like ZH_TW, but also a bit like ZH_HK */ | |
603 "Yahoo! ID:", | |
604 "沒有提供", | |
605 "沒有回答", | |
606 "個人Email地址", | |
607 "真實姓名:", | |
608 "地點:", | |
609 "年齡:", | |
610 "婚姻狀態:", | |
611 "性別:", | |
612 "職業:", | |
613 "嗜好:", | |
614 "個人近況:", | |
615 "喜歡的名句", | |
616 "連結", | |
617 "沒有個人網頁", | |
618 "個人網頁:", | |
619 "沒有推薦網站連結", | |
620 "推薦網站連結 1:", /* TODO */ | |
621 "推薦網站連結 2:", /* TODO */ | |
622 "推薦網站連結 3:", /* TODO */ | |
623 NULL | |
624 }, | |
625 { XX, NULL, NULL, NULL, NULL, NULL, NULL }, | |
626 }; | |
627 | |
628 static char *yahoo_remove_nonbreaking_spaces(char *str) | |
629 { | |
630 char *p; | |
631 while ((p = strstr(str, " ")) != NULL) { | |
632 *p = ' '; /* Turn 's into ordinary blanks */ | |
633 p += 1; | |
634 memmove(p, p + 5, strlen(p + 5)); | |
635 str[strlen(str) - 5] = '\0'; | |
636 } | |
637 return str; | |
638 } | |
639 | |
9242 | 640 static char *yahoo_tooltip_info_text(YahooGetInfoData *info_data) { |
641 GString *s = g_string_sized_new(80); /* wild guess */ | |
642 GaimBuddy *b; | |
9281 | 643 YahooFriend *f; |
9242 | 644 |
9510 | 645 g_string_printf(s, "<span style=\"font-size: larger\"><b>%s</b></span><br>", |
646 info_data->name); | |
9242 | 647 b = gaim_find_buddy(gaim_connection_get_account(info_data->gc), |
648 info_data->name); | |
649 | |
650 if (b) { | |
651 char *statustext = yahoo_tooltip_text(b); | |
652 if(b->alias && b->alias[0]) { | |
653 char *aliastext = g_markup_escape_text(b->alias, -1); | |
654 g_string_append_printf(s, _("<b>Alias:</b> %s<br>"), aliastext); | |
655 g_free(aliastext); | |
656 } | |
9984 | 657 #if 0 |
9242 | 658 if (b->idle > 0) { |
659 char *idletime = gaim_str_seconds_to_string(time(NULL) - b->idle); | |
660 g_string_append_printf(s, _("<b>%s:</b> %s<br>"), _("Idle"), | |
661 idletime); | |
662 g_free(idletime); | |
663 } | |
9984 | 664 #endif |
9242 | 665 if (statustext) { |
666 g_string_append_printf(s, "%s<br>", statustext); | |
667 g_free(statustext); | |
668 } | |
9281 | 669 if ((f = yahoo_friend_find(info_data->gc, b->name))) { |
670 const char *ip; | |
671 if ((ip = yahoo_friend_get_ip(f))) | |
672 g_string_append_printf(s, _("<b>IP Address:</b> %s<br>"), ip); | |
673 } | |
9242 | 674 } |
675 return g_string_free(s, FALSE); | |
676 } | |
677 | |
678 #if PHOTO_SUPPORT | |
679 | |
680 static char *yahoo_get_photo_url(const char *url_text, const char *name) { | |
681 GString *s = g_string_sized_new(strlen(name) + 8); | |
682 char *p; | |
683 char *it = NULL; | |
684 | |
11045
d456fdaf6c73
[gaim-migrate @ 12961]
Richard Laager <rlaager@wiktel.com>
parents:
10604
diff
changeset
|
685 /*g_string_printf(s, " alt=\"%s\">", name);*/ |
d456fdaf6c73
[gaim-migrate @ 12961]
Richard Laager <rlaager@wiktel.com>
parents:
10604
diff
changeset
|
686 /* Y! newformat */ |
d456fdaf6c73
[gaim-migrate @ 12961]
Richard Laager <rlaager@wiktel.com>
parents:
10604
diff
changeset
|
687 g_string_printf(s, " alt=%s>", name); |
9242 | 688 p = strstr(url_text, s->str); |
689 | |
690 if (p) { | |
691 /* Search backwards for "http://". This is stupid, but it works. */ | |
692 for (; !it && p > url_text; p -= 1) { | |
11045
d456fdaf6c73
[gaim-migrate @ 12961]
Richard Laager <rlaager@wiktel.com>
parents:
10604
diff
changeset
|
693 /*if (strncmp(p, "\"http://", 8) == 0) {*/ |
d456fdaf6c73
[gaim-migrate @ 12961]
Richard Laager <rlaager@wiktel.com>
parents:
10604
diff
changeset
|
694 /* Y! newformat*/ |
d456fdaf6c73
[gaim-migrate @ 12961]
Richard Laager <rlaager@wiktel.com>
parents:
10604
diff
changeset
|
695 if (strncmp(p, "=http://", 8) == 0) { |
9242 | 696 char *q; |
11045
d456fdaf6c73
[gaim-migrate @ 12961]
Richard Laager <rlaager@wiktel.com>
parents:
10604
diff
changeset
|
697 p += 1; /* skip only the ' ' */ |
d456fdaf6c73
[gaim-migrate @ 12961]
Richard Laager <rlaager@wiktel.com>
parents:
10604
diff
changeset
|
698 q = strchr(p, ' '); |
9242 | 699 if (q) { |
700 it = g_strndup(p, q - p); | |
701 } | |
702 } | |
703 } | |
704 } | |
705 | |
706 g_string_free(s, TRUE); | |
707 return it; | |
708 } | |
709 | |
710 static void yahoo_got_photo(void *data, const char *url_text, size_t len); | |
711 | |
712 #endif /* PHOTO_SUPPORT */ | |
713 | |
9162 | 714 static void yahoo_got_info(void *data, const char *url_text, size_t len) |
715 { | |
716 YahooGetInfoData *info_data = (YahooGetInfoData *)data; | |
9242 | 717 char *p; |
9162 | 718 char buf[1024]; |
9242 | 719 #if PHOTO_SUPPORT |
720 YahooGetInfoStepTwoData *info2_data; | |
721 char *photo_url_text = NULL; | |
722 #else | |
9162 | 723 gboolean found = FALSE; |
9242 | 724 char *stripped; |
725 int stripped_len; | |
726 char *last_updated_utf8_string = NULL; | |
727 #endif | |
728 const char *last_updated_string = NULL; | |
9162 | 729 char *url_buffer; |
730 GString *s; | |
9242 | 731 char *tooltip_text = NULL; |
732 char *profile_url_text = NULL; | |
9162 | 733 int lang, strid; |
9221 | 734 struct yahoo_data *yd; |
9242 | 735 const profile_strings_node_t *strings = NULL; |
9510 | 736 const char *title; |
737 profile_state_t profile_state = PROFILE_STATE_DEFAULT; | |
9221 | 738 |
739 if (!GAIM_CONNECTION_IS_VALID(info_data->gc)) { | |
740 g_free(info_data->name); | |
741 g_free(info_data); | |
742 return; | |
743 } | |
9162 | 744 |
745 gaim_debug_info("yahoo", "In yahoo_got_info\n"); | |
746 | |
9221 | 747 yd = info_data->gc->proto_data; |
9510 | 748 title = (yd->jp? _("Yahoo! Japan Profile") : |
749 _("Yahoo! Profile")); | |
9242 | 750 |
751 /* Get the tooltip info string */ | |
752 tooltip_text = yahoo_tooltip_info_text(info_data); | |
9221 | 753 |
9242 | 754 /* We failed to grab the profile URL. This is not expected to actually |
755 * happen except under unusual error conditions, as Yahoo is observed | |
756 * to send back HTML, with a 200 status code. | |
757 */ | |
9162 | 758 if (url_text == NULL || strcmp(url_text, "") == 0) { |
9242 | 759 g_snprintf(buf, 1024, "<html><body>%s<b>%s</b></body></html>", |
760 tooltip_text, _("Error retrieving profile")); | |
761 | |
11533
c9b815aeddc1
[gaim-migrate @ 13782]
Richard Laager <rlaager@wiktel.com>
parents:
11531
diff
changeset
|
762 gaim_notify_userinfo(info_data->gc, info_data->name, |
c9b815aeddc1
[gaim-migrate @ 13782]
Richard Laager <rlaager@wiktel.com>
parents:
11531
diff
changeset
|
763 buf, NULL, NULL); |
9162 | 764 |
9242 | 765 g_free(profile_url_text); |
766 g_free(tooltip_text); | |
9162 | 767 g_free(info_data->name); |
768 g_free(info_data); | |
769 return; | |
770 } | |
771 | |
9242 | 772 /* Construct the correct profile URL */ |
773 s = g_string_sized_new(80); /* wild guess */ | |
774 g_string_printf(s, "%s%s", (yd->jp? YAHOOJP_PROFILE_URL: YAHOO_PROFILE_URL), | |
775 info_data->name); | |
776 profile_url_text = g_string_free(s, FALSE); | |
777 s = NULL; | |
778 | |
779 /* We don't yet support the multiple link level of the warning page for | |
9162 | 780 * 'adult' profiles, not to mention the fact that yahoo wants you to be |
9242 | 781 * logged in (on the website) to be able to view an 'adult' profile. For |
9162 | 782 * now, just tell them that we can't help them, and provide a link to the |
783 * profile if they want to do the web browser thing. | |
784 */ | |
785 p = strstr(url_text, "Adult Profiles Warning Message"); | |
9242 | 786 if (!p) { |
787 p = strstr(url_text, "Adult Content Warning"); /* TITLE element */ | |
788 } | |
9162 | 789 if (p) { |
9242 | 790 g_snprintf(buf, 1024, "<html><body>%s<b>%s</b><br><br>\n" |
791 "%s<br><a href=\"%s\">%s</a></body></html>", | |
792 tooltip_text, | |
793 _("Sorry, profiles marked as containing adult content " | |
794 "are not supported at this time."), | |
795 _("If you wish to view this profile, " | |
796 "you will need to visit this link in your web browser"), | |
797 profile_url_text, profile_url_text); | |
9162 | 798 |
11533
c9b815aeddc1
[gaim-migrate @ 13782]
Richard Laager <rlaager@wiktel.com>
parents:
11531
diff
changeset
|
799 gaim_notify_userinfo(info_data->gc, info_data->name, |
c9b815aeddc1
[gaim-migrate @ 13782]
Richard Laager <rlaager@wiktel.com>
parents:
11531
diff
changeset
|
800 buf, NULL, NULL); |
9162 | 801 |
9242 | 802 g_free(profile_url_text); |
803 g_free(tooltip_text); | |
9162 | 804 g_free(info_data->name); |
805 g_free(info_data); | |
806 return; | |
807 } | |
808 | |
809 /* Check whether the profile is written in a supported language */ | |
810 for (lang = 0;; lang += 1) { | |
811 last_updated_string = profile_langs[lang].last_updated_string; | |
812 if (!last_updated_string) break; | |
813 p = strstr(url_text, last_updated_string); | |
814 if (p && profile_langs[lang].det && !strstr(url_text, profile_langs[lang].det)) { | |
815 p = NULL; | |
816 } | |
817 if (p) break; | |
818 } | |
819 if (p) { | |
820 for (strid = 0; profile_strings[strid].lang != XX; strid += 1) { | |
9221 | 821 if (profile_strings[strid].lang == profile_langs[lang].lang) break; |
9162 | 822 } |
9242 | 823 strings = profile_strings + strid; |
9162 | 824 gaim_debug_info("yahoo", "detected profile lang = %s (%d)\n", profile_strings[strid].lang_string, lang); |
825 } | |
826 | |
9220 | 827 /* Every user may choose his/her own profile language, and this language |
828 * has nothing to do with the preferences of the user which looks at the | |
829 * profile. We try to support all languages, but nothing is guaranteed. | |
9242 | 830 * If we cannot determine the language, it means either (1) the profile |
831 * is written in an unsupported language, (2) our language support is | |
11045
d456fdaf6c73
[gaim-migrate @ 12961]
Richard Laager <rlaager@wiktel.com>
parents:
10604
diff
changeset
|
832 * out of date, or (3) the user is not found, or (4) Y! have changed their |
d456fdaf6c73
[gaim-migrate @ 12961]
Richard Laager <rlaager@wiktel.com>
parents:
10604
diff
changeset
|
833 * webpage layout |
9162 | 834 */ |
9242 | 835 if (!p || strings->lang == XX) { |
836 if (!strstr(url_text, "Yahoo! Member Directory - User not found") | |
837 && !strstr(url_text, "was not found on this server.") | |
838 && !strstr(url_text, "\xb8\xf8\xb3\xab\xa5\xd7\xa5\xed\xa5\xd5\xa5\xa3\xa1\xbc\xa5\xeb\xa4\xac\xb8\xab\xa4\xc4\xa4\xab\xa4\xea\xa4\xde\xa4\xbb\xa4\xf3")) { | |
9510 | 839 profile_state = PROFILE_STATE_UNKNOWN_LANGUAGE; |
9162 | 840 } else { |
9510 | 841 profile_state = PROFILE_STATE_NOT_FOUND; |
9162 | 842 } |
843 } | |
844 | |
9242 | 845 #if PHOTO_SUPPORT |
846 photo_url_text = yahoo_get_photo_url(url_text, info_data->name); | |
847 #endif | |
848 | |
9162 | 849 url_buffer = g_strdup(url_text); |
850 | |
851 /* | |
852 * gaim_markup_strip_html() doesn't strip out character entities like | |
853 * and · | |
854 */ | |
855 yahoo_remove_nonbreaking_spaces(url_buffer); | |
856 #if 1 | |
857 while ((p = strstr(url_buffer, "·")) != NULL) { | |
858 memmove(p, p + 6, strlen(p + 6)); | |
859 url_buffer[strlen(url_buffer) - 6] = '\0'; | |
860 } | |
861 #endif | |
862 | |
863 /* nuke the nasty \r's */ | |
11920 | 864 gaim_str_strip_char(url_buffer, '\r'); |
9242 | 865 |
866 #if PHOTO_SUPPORT | |
867 /* Marshall the existing state */ | |
868 info2_data = g_malloc(sizeof(YahooGetInfoStepTwoData)); | |
869 info2_data->info_data = info_data; | |
870 info2_data->url_buffer = url_buffer; | |
871 info2_data->s = s; | |
872 info2_data->photo_url_text = photo_url_text; | |
873 info2_data->profile_url_text = profile_url_text; | |
874 info2_data->tooltip_text = tooltip_text; | |
875 info2_data->strings = strings; | |
876 info2_data->last_updated_string = last_updated_string; | |
9510 | 877 info2_data->title = title; |
878 info2_data->profile_state = profile_state; | |
9242 | 879 |
880 /* Try to put the photo in there too, if there's one */ | |
881 if (photo_url_text) { | |
882 /* User-uploaded photos use a different server that requires the Host | |
883 * header, but Yahoo Japan will use the "chunked" content encoding if | |
884 * we specify HTTP 1.1. So we have to specify 1.0 & fix gaim_url_fetch | |
885 */ | |
886 gaim_url_fetch(photo_url_text, FALSE, NULL, FALSE, yahoo_got_photo, | |
887 info2_data); | |
888 } else { | |
889 /* Emulate a callback */ | |
890 yahoo_got_photo(info2_data, NULL, 0); | |
9162 | 891 } |
9242 | 892 } |
893 | |
894 static void yahoo_got_photo(void *data, const char *url_text, size_t len) | |
895 { | |
896 YahooGetInfoStepTwoData *info2_data = (YahooGetInfoStepTwoData *)data; | |
897 gboolean found = FALSE; | |
898 int id = -1; | |
899 | |
900 /* Temporary variables */ | |
901 char *p = NULL; | |
902 char *stripped; | |
903 int stripped_len; | |
904 char *last_updated_utf8_string = NULL; | |
905 | |
906 /* Unmarshall the saved state */ | |
907 YahooGetInfoData *info_data = info2_data->info_data; | |
908 char *url_buffer = info2_data->url_buffer; | |
909 GString *s = info2_data->s; | |
910 char *photo_url_text = info2_data->photo_url_text; | |
911 char *profile_url_text = info2_data->profile_url_text; | |
912 char *tooltip_text = info2_data->tooltip_text; | |
913 const profile_strings_node_t *strings = info2_data->strings; | |
914 const char *last_updated_string = info2_data->last_updated_string; | |
9510 | 915 profile_state_t profile_state = info2_data->profile_state; |
9242 | 916 |
917 /* We continue here from yahoo_got_info, as if nothing has happened */ | |
918 #endif /* PHOTO_SUPPORT */ | |
9162 | 919 |
11045
d456fdaf6c73
[gaim-migrate @ 12961]
Richard Laager <rlaager@wiktel.com>
parents:
10604
diff
changeset
|
920 /* Jun 29 05 Bleeter: Y! changed their profile pages. Terminators now seem to be */ |
d456fdaf6c73
[gaim-migrate @ 12961]
Richard Laager <rlaager@wiktel.com>
parents:
10604
diff
changeset
|
921 /* </dd> and not \n. The prpl's need to be audited before it can be moved */ |
d456fdaf6c73
[gaim-migrate @ 12961]
Richard Laager <rlaager@wiktel.com>
parents:
10604
diff
changeset
|
922 /* in to gaim_markup_strip_html*/ |
d456fdaf6c73
[gaim-migrate @ 12961]
Richard Laager <rlaager@wiktel.com>
parents:
10604
diff
changeset
|
923 char *fudged_buffer; |
d456fdaf6c73
[gaim-migrate @ 12961]
Richard Laager <rlaager@wiktel.com>
parents:
10604
diff
changeset
|
924 fudged_buffer = gaim_strcasereplace(url_buffer, "</dd>", "</dd><br>"); |
9162 | 925 /* nuke the html, it's easier than trying to parse the horrid stuff */ |
11045
d456fdaf6c73
[gaim-migrate @ 12961]
Richard Laager <rlaager@wiktel.com>
parents:
10604
diff
changeset
|
926 stripped = gaim_markup_strip_html(fudged_buffer); |
9162 | 927 stripped_len = strlen(stripped); |
928 | |
929 gaim_debug_misc("yahoo", "stripped = %p\n", stripped); | |
930 gaim_debug_misc("yahoo", "url_buffer = %p\n", url_buffer); | |
931 | |
932 /* convert to utf8 */ | |
9510 | 933 if (strings && strings->charset != XX) { |
934 p = g_convert(stripped, -1, "utf-8", strings->charset, | |
935 NULL, NULL, NULL); | |
9162 | 936 if (!p) { |
9510 | 937 p = g_locale_to_utf8(stripped, -1, NULL, NULL, NULL); |
938 if (!p) { | |
939 p = g_convert(stripped, -1, "utf-8", "windows-1252", | |
940 NULL, NULL, NULL); | |
941 } | |
942 } | |
943 if (p) { | |
944 g_free(stripped); | |
945 stripped = gaim_utf8_ncr_decode(p); | |
946 stripped_len = strlen(stripped); | |
947 g_free(p); | |
9162 | 948 } |
949 } | |
9510 | 950 p = NULL; |
9162 | 951 |
952 /* "Last updated" should also be converted to utf8 and with killed */ | |
9510 | 953 if (strings && strings->charset != XX) { |
954 last_updated_utf8_string = g_convert(last_updated_string, -1, "utf-8", | |
955 strings->charset, NULL, NULL, NULL); | |
956 yahoo_remove_nonbreaking_spaces(last_updated_utf8_string); | |
9162 | 957 |
9510 | 958 gaim_debug_misc("yahoo", "after utf8 conversion: stripped = (%s)\n", stripped); |
959 } | |
9162 | 960 |
961 /* gonna re-use the memory we've already got for url_buffer */ | |
962 /* no we're not */ | |
963 s = g_string_sized_new(strlen(url_buffer)); | |
9510 | 964 |
965 if (profile_state == PROFILE_STATE_DEFAULT) { | |
9242 | 966 #if 0 |
9162 | 967 /* extract their Yahoo! ID and put it in. Don't bother marking has_info as |
968 * true, since the Yahoo! ID will always be there */ | |
9242 | 969 if (!gaim_markup_extract_info_field(stripped, stripped_len, s, |
11045
d456fdaf6c73
[gaim-migrate @ 12961]
Richard Laager <rlaager@wiktel.com>
parents:
10604
diff
changeset
|
970 strings->yahoo_id_string, 10, "\n", 0, |
9162 | 971 NULL, _("Yahoo! ID"), 0, NULL)) |
9242 | 972 ; |
973 #endif | |
974 | |
975 #if PHOTO_SUPPORT | |
976 /* Try to put the photo in there too, if there's one and is readable */ | |
977 if (data && url_text && len != 0) { | |
978 if (strstr(url_text, "400 Bad Request") | |
979 || strstr(url_text, "403 Forbidden") | |
980 || strstr(url_text, "404 Not Found")) { | |
981 | |
982 gaim_debug_info("yahoo", "Error getting %s: %s\n", | |
983 photo_url_text, url_text); | |
984 } else { | |
985 gaim_debug_info("yahoo", "%s is %d bytes\n", photo_url_text, len); | |
986 id = gaim_imgstore_add(url_text, len, NULL); | |
987 g_string_append_printf(s, "<img id=\"%d\"><br>", id); | |
9220 | 988 } |
989 } | |
9242 | 990 #endif /* PHOTO_SUPPORT */ |
991 | |
9162 | 992 /* extract their Email address and put it in */ |
9242 | 993 found |= gaim_markup_extract_info_field(stripped, stripped_len, s, |
11045
d456fdaf6c73
[gaim-migrate @ 12961]
Richard Laager <rlaager@wiktel.com>
parents:
10604
diff
changeset
|
994 strings->my_email_string, 1, " ", 0, |
9242 | 995 strings->private_string, _("Email"), 0, NULL); |
9162 | 996 |
997 /* extract the Nickname if it exists */ | |
9242 | 998 found |= gaim_markup_extract_info_field(stripped, stripped_len, s, |
999 "Nickname:", 1, "\n", '\n', | |
9162 | 1000 NULL, _("Nickname"), 0, NULL); |
1001 | |
1002 /* extract their RealName and put it in */ | |
9242 | 1003 found |= gaim_markup_extract_info_field(stripped, stripped_len, s, |
1004 strings->realname_string, 1, "\n", '\n', | |
9162 | 1005 NULL, _("Realname"), 0, NULL); |
1006 | |
1007 /* extract their Location and put it in */ | |
9242 | 1008 found |= gaim_markup_extract_info_field(stripped, stripped_len, s, |
1009 strings->location_string, 2, "\n", '\n', | |
9162 | 1010 NULL, _("Location"), 0, NULL); |
1011 | |
1012 /* extract their Age and put it in */ | |
9242 | 1013 found |= gaim_markup_extract_info_field(stripped, stripped_len, s, |
1014 strings->age_string, 3, "\n", '\n', | |
9162 | 1015 NULL, _("Age"), 0, NULL); |
1016 | |
1017 /* extract their MaritalStatus and put it in */ | |
9242 | 1018 found |= gaim_markup_extract_info_field(stripped, stripped_len, s, |
1019 strings->maritalstatus_string, 3, "\n", '\n', | |
1020 strings->no_answer_string, _("Marital Status"), 0, NULL); | |
9162 | 1021 |
1022 /* extract their Gender and put it in */ | |
9242 | 1023 found |= gaim_markup_extract_info_field(stripped, stripped_len, s, |
1024 strings->gender_string, 3, "\n", '\n', | |
1025 strings->no_answer_string, _("Gender"), 0, NULL); | |
9162 | 1026 |
1027 /* extract their Occupation and put it in */ | |
9242 | 1028 found |= gaim_markup_extract_info_field(stripped, stripped_len, s, |
1029 strings->occupation_string, 2, "\n", '\n', | |
9162 | 1030 NULL, _("Occupation"), 0, NULL); |
1031 | |
9242 | 1032 /* Hobbies, Latest News, and Favorite Quote are a bit different, since |
1033 * the values can contain embedded newlines... but any or all of them | |
1034 * can also not appear. The way we delimit them is to successively | |
1035 * look for the next one that _could_ appear, and if all else fails, | |
1036 * we end the section by looking for the 'Links' heading, which is the | |
1037 * next thing to follow this bunch. (For Yahoo Japan, we check for | |
1038 * the "Description" ("Self PR") heading instead of "Links".) | |
9162 | 1039 */ |
1040 | |
9242 | 1041 if (!gaim_markup_extract_info_field(stripped, stripped_len, s, |
1042 strings->hobbies_string, 1, strings->latest_news_string, | |
11045
d456fdaf6c73
[gaim-migrate @ 12961]
Richard Laager <rlaager@wiktel.com>
parents:
10604
diff
changeset
|
1043 '\n', "\n", _("Hobbies"), 0, NULL)) |
9162 | 1044 { |
9242 | 1045 if (!gaim_markup_extract_info_field(stripped, stripped_len, s, |
1046 strings->hobbies_string, 1, strings->favorite_quote_string, | |
11045
d456fdaf6c73
[gaim-migrate @ 12961]
Richard Laager <rlaager@wiktel.com>
parents:
10604
diff
changeset
|
1047 '\n', "\n", _("Hobbies"), 0, NULL)) |
9162 | 1048 { |
9242 | 1049 found |= gaim_markup_extract_info_field(stripped, stripped_len, s, |
1050 strings->hobbies_string, 1, strings->links_string, | |
11045
d456fdaf6c73
[gaim-migrate @ 12961]
Richard Laager <rlaager@wiktel.com>
parents:
10604
diff
changeset
|
1051 '\n', "\n", _("Hobbies"), 0, NULL); |
9162 | 1052 } |
1053 else | |
1054 found = TRUE; | |
1055 } | |
1056 else | |
1057 found = TRUE; | |
1058 | |
9242 | 1059 if (!gaim_markup_extract_info_field(stripped, stripped_len, s, |
1060 strings->latest_news_string, 1, strings->favorite_quote_string, | |
11045
d456fdaf6c73
[gaim-migrate @ 12961]
Richard Laager <rlaager@wiktel.com>
parents:
10604
diff
changeset
|
1061 '\n', "\n", _("Latest News"), 0, NULL)) |
9162 | 1062 { |
9242 | 1063 found |= gaim_markup_extract_info_field(stripped, stripped_len, s, |
1064 strings->latest_news_string, 1, strings->links_string, | |
11045
d456fdaf6c73
[gaim-migrate @ 12961]
Richard Laager <rlaager@wiktel.com>
parents:
10604
diff
changeset
|
1065 '\n', "\n", _("Latest News"), 0, NULL); |
9162 | 1066 } |
1067 else | |
1068 found = TRUE; | |
1069 | |
9242 | 1070 found |= gaim_markup_extract_info_field(stripped, stripped_len, s, |
1071 strings->favorite_quote_string, 1, strings->links_string, | |
11045
d456fdaf6c73
[gaim-migrate @ 12961]
Richard Laager <rlaager@wiktel.com>
parents:
10604
diff
changeset
|
1072 '\n', "\n", _("Favorite Quote"), 0, NULL); |
9162 | 1073 |
1074 /* Home Page will either be "No home page specified", | |
1075 * or "Home Page: " and a link. | |
9242 | 1076 * For Yahoo! Japan, if there is no home page specified, |
1077 * neither "No home page specified" nor "Home Page:" is shown. | |
9162 | 1078 */ |
9242 | 1079 if (strings->home_page_string) { |
1080 p = !strings->no_home_page_specified_string? NULL: | |
1081 strstr(stripped, strings->no_home_page_specified_string); | |
9162 | 1082 if(!p) |
1083 { | |
9242 | 1084 found |= gaim_markup_extract_info_field(stripped, stripped_len, s, |
1085 strings->home_page_string, 1, "\n", 0, NULL, | |
9162 | 1086 _("Home Page"), 1, NULL); |
1087 } | |
1088 } | |
1089 | |
9242 | 1090 /* Cool Link {1,2,3} is also different. If "No cool link specified" |
1091 * exists, then we have none. If we have one however, we'll need to | |
1092 * check and see if we have a second one. If we have a second one, | |
1093 * we have to check to see if we have a third one. | |
9162 | 1094 */ |
9242 | 1095 p = !strings->no_cool_link_specified_string? NULL: |
1096 strstr(stripped,strings->no_cool_link_specified_string); | |
9162 | 1097 if (!p) |
1098 { | |
9242 | 1099 if (gaim_markup_extract_info_field(stripped, stripped_len, s, |
1100 strings->cool_link_1_string, 1, "\n", 0, NULL, | |
9162 | 1101 _("Cool Link 1"), 1, NULL)) |
1102 { | |
1103 found = TRUE; | |
9242 | 1104 if (gaim_markup_extract_info_field(stripped, stripped_len, s, |
1105 strings->cool_link_2_string, 1, "\n", 0, NULL, | |
9162 | 1106 _("Cool Link 2"), 1, NULL)) |
9242 | 1107 { |
1108 gaim_markup_extract_info_field(stripped, stripped_len, s, | |
1109 strings->cool_link_3_string, 1, "\n", 0, NULL, | |
9162 | 1110 _("Cool Link 3"), 1, NULL); |
9242 | 1111 } |
9162 | 1112 } |
1113 } | |
1114 | |
1115 /* see if Member Since is there, and if so, extract it. */ | |
9242 | 1116 found |= gaim_markup_extract_info_field(stripped, stripped_len, s, |
1117 "Member Since:", 1, last_updated_utf8_string, | |
9162 | 1118 '\n', NULL, _("Member Since"), 0, NULL); |
1119 | |
1120 /* extract the Last Updated date and put it in */ | |
9242 | 1121 found |= gaim_markup_extract_info_field(stripped, stripped_len, s, |
11045
d456fdaf6c73
[gaim-migrate @ 12961]
Richard Laager <rlaager@wiktel.com>
parents:
10604
diff
changeset
|
1122 last_updated_utf8_string, 1, " ", '\n', NULL, |
d456fdaf6c73
[gaim-migrate @ 12961]
Richard Laager <rlaager@wiktel.com>
parents:
10604
diff
changeset
|
1123 _("Last Update"), 0, NULL); |
9510 | 1124 } /* if (profile_state == PROFILE_STATE_DEFAULT) */ |
1125 | |
1126 if(!found) | |
1127 { | |
1128 g_string_append_printf(s, "<br><b>"); | |
1129 g_string_append_printf(s, _("User information for %s unavailable"), | |
1130 info_data->name); | |
1131 g_string_append_printf(s, "</b><br>"); | |
1132 | |
1133 if (profile_state == PROFILE_STATE_UNKNOWN_LANGUAGE) { | |
1134 g_string_append_printf(s, "%s<br><br>", | |
1135 _("Sorry, this profile seems to be in a language " | |
1136 "that is not supported at this time.")); | |
1137 | |
1138 } else if (profile_state == PROFILE_STATE_NOT_FOUND) { | |
1139 GaimBuddy *b = gaim_find_buddy | |
1140 (gaim_connection_get_account(info_data->gc), | |
1141 info_data->name); | |
1142 YahooFriend *f = NULL; | |
1143 if (b) { | |
1144 /* Someone on the buddy list can be "not on server list", | |
1145 * in which case the user may or may not actually exist. | |
1146 * Hence this extra step. | |
1147 */ | |
1148 f = yahoo_friend_find(b->account->gc, b->name); | |
1149 } | |
1150 g_string_append_printf(s, "%s<br><br>", | |
1151 f? _("Could not retrieve the user's profile. " | |
1152 "This most likely is a temporary server-side problem. " | |
1153 "Please try again later."): | |
1154 _("Could not retrieve the user's profile. " | |
1155 "This most likely means that the user does not exist; " | |
1156 "however, Yahoo! sometimes does fail to find a user's " | |
1157 "profile. If you know that the user exists, " | |
1158 "please try again later.")); | |
1159 | |
1160 } else { | |
1161 g_string_append_printf(s, "%s<br><br>", | |
1162 _("The user's profile is empty.")); | |
1163 } | |
1164 } | |
1165 | |
9220 | 1166 /* put a link to the actual profile URL */ |
1167 g_string_append_printf(s, _("<b>%s:</b> "), _("Profile URL")); | |
9242 | 1168 g_string_append_printf(s, "<br><a href=\"%s\">%s</a><br>", |
1169 profile_url_text, profile_url_text); | |
9220 | 1170 |
9510 | 1171 /* finish off the html at the end */ |
9162 | 1172 g_string_append(s, "</body></html>\n"); |
1173 g_free(stripped); | |
1174 | |
9510 | 1175 /* Put the Yahoo! ID, nickname, idle time, and status message in */ |
1176 g_string_prepend(s, tooltip_text); | |
1177 | |
1178 /* finish off the html at the beginning */ | |
1179 g_string_prepend(s, "<html><body>\n"); | |
1180 | |
1181 /* show it to the user */ | |
11533
c9b815aeddc1
[gaim-migrate @ 13782]
Richard Laager <rlaager@wiktel.com>
parents:
11531
diff
changeset
|
1182 gaim_notify_userinfo(info_data->gc, info_data->name, |
c9b815aeddc1
[gaim-migrate @ 13782]
Richard Laager <rlaager@wiktel.com>
parents:
11531
diff
changeset
|
1183 s->str, NULL, NULL); |
9162 | 1184 |
1185 g_free(last_updated_utf8_string); | |
1186 g_free(url_buffer); | |
11045
d456fdaf6c73
[gaim-migrate @ 12961]
Richard Laager <rlaager@wiktel.com>
parents:
10604
diff
changeset
|
1187 g_free(fudged_buffer); |
9162 | 1188 g_string_free(s, TRUE); |
9242 | 1189 g_free(profile_url_text); |
1190 g_free(tooltip_text); | |
9162 | 1191 g_free(info_data->name); |
1192 g_free(info_data); | |
9242 | 1193 |
1194 #if PHOTO_SUPPORT | |
1195 g_free(photo_url_text); | |
1196 g_free(info2_data); | |
1197 if (id != -1) | |
1198 gaim_imgstore_unref(id); | |
1199 #endif | |
9162 | 1200 } |
1201 | |
1202 void yahoo_get_info(GaimConnection *gc, const char *name) | |
1203 { | |
9164 | 1204 struct yahoo_data *yd = gc->proto_data; |
9162 | 1205 YahooGetInfoData *data; |
1206 char *url; | |
1207 | |
1208 data = g_new0(YahooGetInfoData, 1); | |
1209 data->gc = gc; | |
1210 data->name = g_strdup(name); | |
1211 | |
9221 | 1212 url = g_strdup_printf("%s%s", |
1213 (yd->jp? YAHOOJP_PROFILE_URL: YAHOO_PROFILE_URL), name); | |
9162 | 1214 |
10604 | 1215 gaim_url_fetch(url, TRUE, NULL, FALSE, yahoo_got_info, data); |
9162 | 1216 |
1217 g_free(url); | |
1218 } |