Sat, 21 Jun 2008 06:15:38 +0000
Sometimes (after 24h+) when you request a MSN token update, you get a
Collection of Responses, with (presumably) some updated CipherValue and
BinarySecret data that should be used for subsequent update requests.
References #4875.
|
9198
e8eb6d5eb9eb
[gaim-migrate @ 9993]
Christian Hammond <chipx86@chipx86.com>
parents:
9193
diff
changeset
|
1 | /** |
|
e8eb6d5eb9eb
[gaim-migrate @ 9993]
Christian Hammond <chipx86@chipx86.com>
parents:
9193
diff
changeset
|
2 | * @file nexus.c MSN Nexus functions |
|
e8eb6d5eb9eb
[gaim-migrate @ 9993]
Christian Hammond <chipx86@chipx86.com>
parents:
9193
diff
changeset
|
3 | * |
| 15884 | 4 | * purple |
|
9198
e8eb6d5eb9eb
[gaim-migrate @ 9993]
Christian Hammond <chipx86@chipx86.com>
parents:
9193
diff
changeset
|
5 | * |
| 15884 | 6 | * Purple is the legal property of its developers, whose names are too numerous |
|
9198
e8eb6d5eb9eb
[gaim-migrate @ 9993]
Christian Hammond <chipx86@chipx86.com>
parents:
9193
diff
changeset
|
7 | * to list here. Please refer to the COPYRIGHT file distributed with this |
|
e8eb6d5eb9eb
[gaim-migrate @ 9993]
Christian Hammond <chipx86@chipx86.com>
parents:
9193
diff
changeset
|
8 | * source distribution. |
|
e8eb6d5eb9eb
[gaim-migrate @ 9993]
Christian Hammond <chipx86@chipx86.com>
parents:
9193
diff
changeset
|
9 | * |
|
e8eb6d5eb9eb
[gaim-migrate @ 9993]
Christian Hammond <chipx86@chipx86.com>
parents:
9193
diff
changeset
|
10 | * This program is free software; you can redistribute it and/or modify |
|
e8eb6d5eb9eb
[gaim-migrate @ 9993]
Christian Hammond <chipx86@chipx86.com>
parents:
9193
diff
changeset
|
11 | * it under the terms of the GNU General Public License as published by |
|
e8eb6d5eb9eb
[gaim-migrate @ 9993]
Christian Hammond <chipx86@chipx86.com>
parents:
9193
diff
changeset
|
12 | * the Free Software Foundation; either version 2 of the License, or |
|
e8eb6d5eb9eb
[gaim-migrate @ 9993]
Christian Hammond <chipx86@chipx86.com>
parents:
9193
diff
changeset
|
13 | * (at your option) any later version. |
|
e8eb6d5eb9eb
[gaim-migrate @ 9993]
Christian Hammond <chipx86@chipx86.com>
parents:
9193
diff
changeset
|
14 | * |
|
e8eb6d5eb9eb
[gaim-migrate @ 9993]
Christian Hammond <chipx86@chipx86.com>
parents:
9193
diff
changeset
|
15 | * This program is distributed in the hope that it will be useful, |
|
e8eb6d5eb9eb
[gaim-migrate @ 9993]
Christian Hammond <chipx86@chipx86.com>
parents:
9193
diff
changeset
|
16 | * but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
e8eb6d5eb9eb
[gaim-migrate @ 9993]
Christian Hammond <chipx86@chipx86.com>
parents:
9193
diff
changeset
|
17 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
e8eb6d5eb9eb
[gaim-migrate @ 9993]
Christian Hammond <chipx86@chipx86.com>
parents:
9193
diff
changeset
|
18 | * GNU General Public License for more details. |
|
e8eb6d5eb9eb
[gaim-migrate @ 9993]
Christian Hammond <chipx86@chipx86.com>
parents:
9193
diff
changeset
|
19 | * |
|
e8eb6d5eb9eb
[gaim-migrate @ 9993]
Christian Hammond <chipx86@chipx86.com>
parents:
9193
diff
changeset
|
20 | * You should have received a copy of the GNU General Public License |
|
e8eb6d5eb9eb
[gaim-migrate @ 9993]
Christian Hammond <chipx86@chipx86.com>
parents:
9193
diff
changeset
|
21 | * along with this program; if not, write to the Free Software |
|
19859
71d37b57eff2
The FSF changed its address a while ago; our files were out of date.
John Bailey <rekkanoryo@rekkanoryo.org>
parents:
19832
diff
changeset
|
22 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02111-1301 USA |
|
9198
e8eb6d5eb9eb
[gaim-migrate @ 9993]
Christian Hammond <chipx86@chipx86.com>
parents:
9193
diff
changeset
|
23 | */ |
|
8171
c3c43a25caec
[gaim-migrate @ 8884]
Felipe Contreras <felipe.contreras@gmail.com>
parents:
diff
changeset
|
24 | #include "msn.h" |
|
21357
64a63a153c62
the new soap code finally doesn't crash on startup, still can't
Ka-Hing Cheung <khc@pidgin.im>
parents:
20597
diff
changeset
|
25 | #include "soap2.h" |
|
8171
c3c43a25caec
[gaim-migrate @ 8884]
Felipe Contreras <felipe.contreras@gmail.com>
parents:
diff
changeset
|
26 | #include "nexus.h" |
|
c3c43a25caec
[gaim-migrate @ 8884]
Felipe Contreras <felipe.contreras@gmail.com>
parents:
diff
changeset
|
27 | #include "notification.h" |
|
c3c43a25caec
[gaim-migrate @ 8884]
Felipe Contreras <felipe.contreras@gmail.com>
parents:
diff
changeset
|
28 | |
|
23756
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
29 | /************************************************************************** |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
30 | * Valid Ticket Tokens |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
31 | **************************************************************************/ |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
32 | |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
33 | #define SSO_VALID_TICKET_DOMAIN 0 |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
34 | #define SSO_VALID_TICKET_POLICY 1 |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
35 | static char *ticket_domains[][2] = { |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
36 | /* http://msnpiki.msnfanatic.com/index.php/MSNP15:SSO */ |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
37 | /* {"Domain", "Policy Ref URI"}, Purpose */ |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
38 | {"messengerclear.live.com", NULL}, /* Authentication for messenger. */ |
|
23764
a20c976bf63f
References #4382, fixes getting offline messages in p15
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23762
diff
changeset
|
39 | {"messenger.msn.com", "?id=507"}, /* Authentication for receiving OIMs. */ |
|
23756
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
40 | {"contacts.msn.com", "MBI"}, /* Authentication for the Contact server. */ |
|
23764
a20c976bf63f
References #4382, fixes getting offline messages in p15
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23762
diff
changeset
|
41 | {"messengersecure.live.com", "MBI_SSL"}, /* Authentication for sending OIMs. */ |
|
23756
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
42 | {"spaces.live.com", "MBI"}, /* Authentication for the Windows Live Spaces */ |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
43 | {"livecontacts.live.com", "MBI"}, /* Live Contacts API, a simplified version of the Contacts SOAP service */ |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
44 | {"storage.live.com", "MBI"}, /* Storage REST API */ |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
45 | }; |
| 13907 | 46 | |
|
8171
c3c43a25caec
[gaim-migrate @ 8884]
Felipe Contreras <felipe.contreras@gmail.com>
parents:
diff
changeset
|
47 | /************************************************************************** |
|
10481
a5d6b8e1717d
[gaim-migrate @ 11769]
Felipe Contreras <felipe.contreras@gmail.com>
parents:
10345
diff
changeset
|
48 | * Main |
|
a5d6b8e1717d
[gaim-migrate @ 11769]
Felipe Contreras <felipe.contreras@gmail.com>
parents:
10345
diff
changeset
|
49 | **************************************************************************/ |
|
a5d6b8e1717d
[gaim-migrate @ 11769]
Felipe Contreras <felipe.contreras@gmail.com>
parents:
10345
diff
changeset
|
50 | |
|
a5d6b8e1717d
[gaim-migrate @ 11769]
Felipe Contreras <felipe.contreras@gmail.com>
parents:
10345
diff
changeset
|
51 | MsnNexus * |
|
a5d6b8e1717d
[gaim-migrate @ 11769]
Felipe Contreras <felipe.contreras@gmail.com>
parents:
10345
diff
changeset
|
52 | msn_nexus_new(MsnSession *session) |
|
a5d6b8e1717d
[gaim-migrate @ 11769]
Felipe Contreras <felipe.contreras@gmail.com>
parents:
10345
diff
changeset
|
53 | { |
|
a5d6b8e1717d
[gaim-migrate @ 11769]
Felipe Contreras <felipe.contreras@gmail.com>
parents:
10345
diff
changeset
|
54 | MsnNexus *nexus; |
|
23756
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
55 | int i; |
|
10481
a5d6b8e1717d
[gaim-migrate @ 11769]
Felipe Contreras <felipe.contreras@gmail.com>
parents:
10345
diff
changeset
|
56 | |
|
a5d6b8e1717d
[gaim-migrate @ 11769]
Felipe Contreras <felipe.contreras@gmail.com>
parents:
10345
diff
changeset
|
57 | nexus = g_new0(MsnNexus, 1); |
|
a5d6b8e1717d
[gaim-migrate @ 11769]
Felipe Contreras <felipe.contreras@gmail.com>
parents:
10345
diff
changeset
|
58 | nexus->session = session; |
| 13855 | 59 | |
|
23756
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
60 | nexus->token_len = sizeof(ticket_domains) / sizeof(char *[2]); |
|
23767
99a6b7205637
zero out this, side effect is not crashing when password is incorrect
Ka-Hing Cheung <khc@pidgin.im>
parents:
23765
diff
changeset
|
61 | nexus->tokens = g_new0(MsnTicketToken, nexus->token_len); |
|
23756
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
62 | |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
63 | for (i = 0; i < nexus->token_len; i++) |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
64 | nexus->tokens[i].token = g_hash_table_new_full(g_str_hash, g_str_equal, |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
65 | g_free, g_free); |
|
10481
a5d6b8e1717d
[gaim-migrate @ 11769]
Felipe Contreras <felipe.contreras@gmail.com>
parents:
10345
diff
changeset
|
66 | |
|
a5d6b8e1717d
[gaim-migrate @ 11769]
Felipe Contreras <felipe.contreras@gmail.com>
parents:
10345
diff
changeset
|
67 | return nexus; |
|
a5d6b8e1717d
[gaim-migrate @ 11769]
Felipe Contreras <felipe.contreras@gmail.com>
parents:
10345
diff
changeset
|
68 | } |
|
a5d6b8e1717d
[gaim-migrate @ 11769]
Felipe Contreras <felipe.contreras@gmail.com>
parents:
10345
diff
changeset
|
69 | |
|
a5d6b8e1717d
[gaim-migrate @ 11769]
Felipe Contreras <felipe.contreras@gmail.com>
parents:
10345
diff
changeset
|
70 | void |
|
a5d6b8e1717d
[gaim-migrate @ 11769]
Felipe Contreras <felipe.contreras@gmail.com>
parents:
10345
diff
changeset
|
71 | msn_nexus_destroy(MsnNexus *nexus) |
|
a5d6b8e1717d
[gaim-migrate @ 11769]
Felipe Contreras <felipe.contreras@gmail.com>
parents:
10345
diff
changeset
|
72 | { |
|
23756
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
73 | int i; |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
74 | for (i = 0; i < nexus->token_len; i++) { |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
75 | g_hash_table_destroy(nexus->tokens[i].token); |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
76 | g_free(nexus->tokens[i].secret); |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
77 | } |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
78 | |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
79 | g_free(nexus->tokens); |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
80 | g_free(nexus->policy); |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
81 | g_free(nexus->nonce); |
|
23780
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
82 | g_free(nexus->cipher); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
83 | g_free(nexus->secret); |
|
23756
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
84 | g_free(nexus); |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
85 | } |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
86 | |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
87 | /************************************************************************** |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
88 | * RPS/SSO Authentication |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
89 | **************************************************************************/ |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
90 | |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
91 | static char * |
|
23780
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
92 | rps_create_key(const char *key, int key_len, const char *data, size_t data_len) |
|
23756
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
93 | { |
|
23780
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
94 | const guchar magic[] = "WS-SecureConversation"; |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
95 | const int magic_len = sizeof(magic) - 1; |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
96 | |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
97 | PurpleCipherContext *hmac; |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
98 | guchar hash1[20], hash2[20], hash3[20], hash4[20]; |
|
23756
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
99 | char *result; |
|
23780
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
100 | |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
101 | hmac = purple_cipher_context_new_by_name("hmac", NULL); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
102 | |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
103 | purple_cipher_context_set_option(hmac, "hash", "sha1"); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
104 | purple_cipher_context_set_key_with_len(hmac, (guchar *)key, key_len); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
105 | purple_cipher_context_append(hmac, magic, magic_len); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
106 | purple_cipher_context_append(hmac, (guchar *)data, data_len); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
107 | purple_cipher_context_digest(hmac, sizeof(hash1), hash1, NULL); |
|
23756
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
108 | |
|
23780
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
109 | purple_cipher_context_reset(hmac, NULL); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
110 | purple_cipher_context_set_option(hmac, "hash", "sha1"); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
111 | purple_cipher_context_set_key_with_len(hmac, (guchar *)key, key_len); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
112 | purple_cipher_context_append(hmac, hash1, 20); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
113 | purple_cipher_context_append(hmac, magic, magic_len); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
114 | purple_cipher_context_append(hmac, (guchar *)data, data_len); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
115 | purple_cipher_context_digest(hmac, sizeof(hash2), hash2, NULL); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
116 | |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
117 | purple_cipher_context_reset(hmac, NULL); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
118 | purple_cipher_context_set_option(hmac, "hash", "sha1"); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
119 | purple_cipher_context_set_key_with_len(hmac, (guchar *)key, key_len); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
120 | purple_cipher_context_append(hmac, hash1, 20); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
121 | purple_cipher_context_digest(hmac, sizeof(hash3), hash3, NULL); |
|
23756
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
122 | |
|
23780
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
123 | purple_cipher_context_reset(hmac, NULL); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
124 | purple_cipher_context_set_option(hmac, "hash", "sha1"); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
125 | purple_cipher_context_set_key_with_len(hmac, (guchar *)key, key_len); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
126 | purple_cipher_context_append(hmac, hash3, sizeof(hash3)); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
127 | purple_cipher_context_append(hmac, magic, magic_len); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
128 | purple_cipher_context_append(hmac, (guchar *)data, data_len); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
129 | purple_cipher_context_digest(hmac, sizeof(hash4), hash4, NULL); |
|
23756
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
130 | |
|
23780
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
131 | purple_cipher_context_destroy(hmac); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
132 | |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
133 | result = g_malloc(24); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
134 | memcpy(result, hash2, sizeof(hash2)); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
135 | memcpy(result + sizeof(hash2), hash4, 4); |
|
23756
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
136 | |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
137 | return result; |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
138 | } |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
139 | |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
140 | static char * |
|
23780
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
141 | des3_cbc(const char *key, const char *iv, const char *data, int len, gboolean decrypt) |
|
23756
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
142 | { |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
143 | PurpleCipherContext *des3; |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
144 | char *out; |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
145 | size_t outlen; |
|
10481
a5d6b8e1717d
[gaim-migrate @ 11769]
Felipe Contreras <felipe.contreras@gmail.com>
parents:
10345
diff
changeset
|
146 | |
|
23756
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
147 | des3 = purple_cipher_context_new_by_name("des3", NULL); |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
148 | purple_cipher_context_set_key(des3, (guchar *)key); |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
149 | purple_cipher_context_set_batch_mode(des3, PURPLE_CIPHER_BATCH_MODE_CBC); |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
150 | purple_cipher_context_set_iv(des3, (guchar *)iv, 8); |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
151 | |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
152 | out = g_malloc(len); |
|
23780
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
153 | if (decrypt) |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
154 | purple_cipher_context_decrypt(des3, (guchar *)data, len, (guchar *)out, &outlen); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
155 | else |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
156 | purple_cipher_context_encrypt(des3, (guchar *)data, len, (guchar *)out, &outlen); |
|
23756
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
157 | |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
158 | purple_cipher_context_destroy(des3); |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
159 | |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
160 | return out; |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
161 | } |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
162 | |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
163 | #define CRYPT_MODE_CBC 1 |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
164 | #define CIPHER_TRIPLE_DES 0x6603 |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
165 | #define HASH_SHA1 0x8004 |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
166 | static char * |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
167 | msn_rps_encrypt(MsnNexus *nexus) |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
168 | { |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
169 | MsnUsrKey *usr_key; |
|
23780
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
170 | const char magic1[] = "SESSION KEY HASH"; |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
171 | const char magic2[] = "SESSION KEY ENCRYPTION"; |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
172 | PurpleCipherContext *hmac; |
|
23756
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
173 | size_t len; |
|
23780
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
174 | guchar hash[20]; |
|
23756
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
175 | char *key1, *key2, *key3; |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
176 | gsize key1_len; |
|
23780
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
177 | int *iv; |
|
23756
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
178 | char *nonce_fixed; |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
179 | char *cipher; |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
180 | char *response; |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
181 | |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
182 | usr_key = g_malloc(sizeof(MsnUsrKey)); |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
183 | usr_key->size = GUINT32_TO_LE(28); |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
184 | usr_key->crypt_mode = GUINT32_TO_LE(CRYPT_MODE_CBC); |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
185 | usr_key->cipher_type = GUINT32_TO_LE(CIPHER_TRIPLE_DES); |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
186 | usr_key->hash_type = GUINT32_TO_LE(HASH_SHA1); |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
187 | usr_key->iv_len = GUINT32_TO_LE(8); |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
188 | usr_key->hash_len = GUINT32_TO_LE(20); |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
189 | usr_key->cipher_len = GUINT32_TO_LE(72); |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
190 | |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
191 | key1 = (char *)purple_base64_decode((const char *)nexus->tokens[MSN_AUTH_MESSENGER].secret, &key1_len); |
|
23780
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
192 | key2 = rps_create_key(key1, key1_len, magic1, sizeof(magic1) - 1); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
193 | key3 = rps_create_key(key1, key1_len, magic2, sizeof(magic2) - 1); |
|
23756
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
194 | |
|
23780
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
195 | iv = (int *)usr_key->iv; |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
196 | iv[0] = rand(); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
197 | iv[1] = rand(); |
|
23756
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
198 | |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
199 | len = strlen(nexus->nonce); |
|
23780
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
200 | hmac = purple_cipher_context_new_by_name("hmac", NULL); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
201 | purple_cipher_context_set_option(hmac, "hash", "sha1"); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
202 | purple_cipher_context_set_key_with_len(hmac, (guchar *)key2, 24); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
203 | purple_cipher_context_append(hmac, (guchar *)nexus->nonce, len); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
204 | purple_cipher_context_digest(hmac, 20, hash, NULL); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
205 | purple_cipher_context_destroy(hmac); |
|
23756
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
206 | |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
207 | /* We need to pad this to 72 bytes, apparently */ |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
208 | nonce_fixed = g_malloc(len + 8); |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
209 | memcpy(nonce_fixed, nexus->nonce, len); |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
210 | memset(nonce_fixed + len, 0x08, 8); |
|
23780
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
211 | cipher = des3_cbc(key3, usr_key->iv, nonce_fixed, len + 8, FALSE); |
|
23756
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
212 | g_free(nonce_fixed); |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
213 | |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
214 | memcpy(usr_key->hash, hash, 20); |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
215 | memcpy(usr_key->cipher, cipher, 72); |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
216 | |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
217 | g_free(key1); |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
218 | g_free(key2); |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
219 | g_free(key3); |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
220 | g_free(cipher); |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
221 | |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
222 | response = purple_base64_encode((guchar *)usr_key, sizeof(MsnUsrKey)); |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
223 | |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
224 | g_free(usr_key); |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
225 | |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
226 | return response; |
|
10481
a5d6b8e1717d
[gaim-migrate @ 11769]
Felipe Contreras <felipe.contreras@gmail.com>
parents:
10345
diff
changeset
|
227 | } |
|
a5d6b8e1717d
[gaim-migrate @ 11769]
Felipe Contreras <felipe.contreras@gmail.com>
parents:
10345
diff
changeset
|
228 | |
|
8171
c3c43a25caec
[gaim-migrate @ 8884]
Felipe Contreras <felipe.contreras@gmail.com>
parents:
diff
changeset
|
229 | /************************************************************************** |
|
c3c43a25caec
[gaim-migrate @ 8884]
Felipe Contreras <felipe.contreras@gmail.com>
parents:
diff
changeset
|
230 | * Login |
|
c3c43a25caec
[gaim-migrate @ 8884]
Felipe Contreras <felipe.contreras@gmail.com>
parents:
diff
changeset
|
231 | **************************************************************************/ |
|
c3c43a25caec
[gaim-migrate @ 8884]
Felipe Contreras <felipe.contreras@gmail.com>
parents:
diff
changeset
|
232 | |
|
23780
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
233 | /* Used to specify which token to update when only doing single updates */ |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
234 | typedef struct _MsnNexusUpdateData MsnNexusUpdateData; |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
235 | struct _MsnNexusUpdateData { |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
236 | MsnNexus *nexus; |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
237 | int id; |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
238 | GSourceFunc cb; |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
239 | gpointer data; |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
240 | }; |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
241 | |
|
23788
b5ab3fd1c440
Finally got MSN token updating working (I think).
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23780
diff
changeset
|
242 | static gboolean |
|
b5ab3fd1c440
Finally got MSN token updating working (I think).
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23780
diff
changeset
|
243 | nexus_parse_token(MsnNexus *nexus, int id, xmlnode *node) |
|
23780
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
244 | { |
|
23788
b5ab3fd1c440
Finally got MSN token updating working (I think).
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23780
diff
changeset
|
245 | char *token_str, *expiry_str; |
|
b5ab3fd1c440
Finally got MSN token updating working (I think).
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23780
diff
changeset
|
246 | const char *id_str; |
|
23780
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
247 | char **elems, **cur, **tokens; |
|
23788
b5ab3fd1c440
Finally got MSN token updating working (I think).
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23780
diff
changeset
|
248 | xmlnode *token = xmlnode_get_child(node, "RequestedSecurityToken/BinarySecurityToken"); |
|
b5ab3fd1c440
Finally got MSN token updating working (I think).
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23780
diff
changeset
|
249 | xmlnode *secret = xmlnode_get_child(node, "RequestedProofToken/BinarySecret"); |
|
b5ab3fd1c440
Finally got MSN token updating working (I think).
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23780
diff
changeset
|
250 | xmlnode *expires = xmlnode_get_child(node, "LifeTime/Expires"); |
|
b5ab3fd1c440
Finally got MSN token updating working (I think).
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23780
diff
changeset
|
251 | |
|
b5ab3fd1c440
Finally got MSN token updating working (I think).
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23780
diff
changeset
|
252 | if (!token) |
|
b5ab3fd1c440
Finally got MSN token updating working (I think).
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23780
diff
changeset
|
253 | return FALSE; |
|
23780
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
254 | |
|
23788
b5ab3fd1c440
Finally got MSN token updating working (I think).
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23780
diff
changeset
|
255 | /* Use the ID that the server sent us */ |
|
b5ab3fd1c440
Finally got MSN token updating working (I think).
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23780
diff
changeset
|
256 | if (id == -1) { |
|
b5ab3fd1c440
Finally got MSN token updating working (I think).
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23780
diff
changeset
|
257 | id_str = xmlnode_get_attrib(token, "Id"); |
|
b5ab3fd1c440
Finally got MSN token updating working (I think).
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23780
diff
changeset
|
258 | if (id_str == NULL) |
|
b5ab3fd1c440
Finally got MSN token updating working (I think).
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23780
diff
changeset
|
259 | return FALSE; |
|
b5ab3fd1c440
Finally got MSN token updating working (I think).
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23780
diff
changeset
|
260 | |
|
b5ab3fd1c440
Finally got MSN token updating working (I think).
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23780
diff
changeset
|
261 | id = atol(id_str + 7) - 1; /* 'Compact#' or 'PPToken#' */ |
|
b5ab3fd1c440
Finally got MSN token updating working (I think).
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23780
diff
changeset
|
262 | if (id >= nexus->token_len) |
|
b5ab3fd1c440
Finally got MSN token updating working (I think).
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23780
diff
changeset
|
263 | return FALSE; /* Where did this come from? */ |
|
b5ab3fd1c440
Finally got MSN token updating working (I think).
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23780
diff
changeset
|
264 | } |
|
b5ab3fd1c440
Finally got MSN token updating working (I think).
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23780
diff
changeset
|
265 | |
|
b5ab3fd1c440
Finally got MSN token updating working (I think).
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23780
diff
changeset
|
266 | token_str = xmlnode_get_data(token); |
|
b5ab3fd1c440
Finally got MSN token updating working (I think).
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23780
diff
changeset
|
267 | if (token_str == NULL) |
|
b5ab3fd1c440
Finally got MSN token updating working (I think).
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23780
diff
changeset
|
268 | return FALSE; |
|
b5ab3fd1c440
Finally got MSN token updating working (I think).
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23780
diff
changeset
|
269 | |
|
23805
024a2801725c
Sometimes (after 24h+) when you request a MSN token update, you get a
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23788
diff
changeset
|
270 | g_hash_table_remove_all(nexus->tokens[id].token); |
|
024a2801725c
Sometimes (after 24h+) when you request a MSN token update, you get a
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23788
diff
changeset
|
271 | |
|
23788
b5ab3fd1c440
Finally got MSN token updating working (I think).
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23780
diff
changeset
|
272 | elems = g_strsplit(token_str, "&", 0); |
|
23780
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
273 | |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
274 | for (cur = elems; *cur != NULL; cur++) { |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
275 | tokens = g_strsplit(*cur, "=", 2); |
|
23788
b5ab3fd1c440
Finally got MSN token updating working (I think).
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23780
diff
changeset
|
276 | g_hash_table_insert(nexus->tokens[id].token, tokens[0], tokens[1]); |
|
23780
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
277 | /* Don't free each of the tokens, only the array. */ |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
278 | g_free(tokens); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
279 | } |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
280 | g_strfreev(elems); |
|
23788
b5ab3fd1c440
Finally got MSN token updating working (I think).
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23780
diff
changeset
|
281 | g_free(token_str); |
|
b5ab3fd1c440
Finally got MSN token updating working (I think).
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23780
diff
changeset
|
282 | |
|
b5ab3fd1c440
Finally got MSN token updating working (I think).
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23780
diff
changeset
|
283 | if (secret) |
|
b5ab3fd1c440
Finally got MSN token updating working (I think).
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23780
diff
changeset
|
284 | nexus->tokens[id].secret = xmlnode_get_data(secret); |
|
b5ab3fd1c440
Finally got MSN token updating working (I think).
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23780
diff
changeset
|
285 | else |
|
b5ab3fd1c440
Finally got MSN token updating working (I think).
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23780
diff
changeset
|
286 | nexus->tokens[id].secret = NULL; |
|
b5ab3fd1c440
Finally got MSN token updating working (I think).
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23780
diff
changeset
|
287 | |
|
b5ab3fd1c440
Finally got MSN token updating working (I think).
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23780
diff
changeset
|
288 | /* Yay for MS using ISO-8601 */ |
|
b5ab3fd1c440
Finally got MSN token updating working (I think).
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23780
diff
changeset
|
289 | expiry_str = xmlnode_get_data(expires); |
|
b5ab3fd1c440
Finally got MSN token updating working (I think).
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23780
diff
changeset
|
290 | nexus->tokens[id].expiry = purple_str_to_time(expiry_str, |
|
b5ab3fd1c440
Finally got MSN token updating working (I think).
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23780
diff
changeset
|
291 | FALSE, NULL, NULL, NULL); |
|
b5ab3fd1c440
Finally got MSN token updating working (I think).
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23780
diff
changeset
|
292 | g_free(expiry_str); |
|
b5ab3fd1c440
Finally got MSN token updating working (I think).
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23780
diff
changeset
|
293 | |
|
b5ab3fd1c440
Finally got MSN token updating working (I think).
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23780
diff
changeset
|
294 | purple_debug_info("msnp15", "Updated ticket for domain '%s', expires at %" G_GINT64_FORMAT ".\n", |
|
b5ab3fd1c440
Finally got MSN token updating working (I think).
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23780
diff
changeset
|
295 | ticket_domains[id][SSO_VALID_TICKET_DOMAIN], |
|
b5ab3fd1c440
Finally got MSN token updating working (I think).
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23780
diff
changeset
|
296 | (gint64)nexus->tokens[id].expiry); |
|
b5ab3fd1c440
Finally got MSN token updating working (I think).
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23780
diff
changeset
|
297 | return TRUE; |
|
23780
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
298 | } |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
299 | |
|
23756
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
300 | static gboolean |
|
23805
024a2801725c
Sometimes (after 24h+) when you request a MSN token update, you get a
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23788
diff
changeset
|
301 | nexus_parse_collection(MsnNexus *nexus, int id, xmlnode *collection) |
|
8171
c3c43a25caec
[gaim-migrate @ 8884]
Felipe Contreras <felipe.contreras@gmail.com>
parents:
diff
changeset
|
302 | { |
|
21357
64a63a153c62
the new soap code finally doesn't crash on startup, still can't
Ka-Hing Cheung <khc@pidgin.im>
parents:
20597
diff
changeset
|
303 | xmlnode *node; |
|
23788
b5ab3fd1c440
Finally got MSN token updating working (I think).
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23780
diff
changeset
|
304 | gboolean result; |
|
21357
64a63a153c62
the new soap code finally doesn't crash on startup, still can't
Ka-Hing Cheung <khc@pidgin.im>
parents:
20597
diff
changeset
|
305 | |
|
23805
024a2801725c
Sometimes (after 24h+) when you request a MSN token update, you get a
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23788
diff
changeset
|
306 | node = xmlnode_get_child(collection, "RequestSecurityTokenResponse"); |
|
21357
64a63a153c62
the new soap code finally doesn't crash on startup, still can't
Ka-Hing Cheung <khc@pidgin.im>
parents:
20597
diff
changeset
|
307 | |
|
23780
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
308 | if (!node) |
|
23756
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
309 | return FALSE; |
|
21357
64a63a153c62
the new soap code finally doesn't crash on startup, still can't
Ka-Hing Cheung <khc@pidgin.im>
parents:
20597
diff
changeset
|
310 | |
|
23805
024a2801725c
Sometimes (after 24h+) when you request a MSN token update, you get a
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23788
diff
changeset
|
311 | result = TRUE; |
|
024a2801725c
Sometimes (after 24h+) when you request a MSN token update, you get a
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23788
diff
changeset
|
312 | for (; node && result; node = node->next) { |
|
024a2801725c
Sometimes (after 24h+) when you request a MSN token update, you get a
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23788
diff
changeset
|
313 | xmlnode *endpoint = xmlnode_get_child(node, "AppliesTo/EndpointReference/Address"); |
|
024a2801725c
Sometimes (after 24h+) when you request a MSN token update, you get a
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23788
diff
changeset
|
314 | char *address = xmlnode_get_data(endpoint); |
|
024a2801725c
Sometimes (after 24h+) when you request a MSN token update, you get a
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23788
diff
changeset
|
315 | |
|
024a2801725c
Sometimes (after 24h+) when you request a MSN token update, you get a
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23788
diff
changeset
|
316 | if (g_str_equal(address, "http://Passport.NET/tb")) { |
|
024a2801725c
Sometimes (after 24h+) when you request a MSN token update, you get a
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23788
diff
changeset
|
317 | /* This node contains the stuff for updating tokens. */ |
|
024a2801725c
Sometimes (after 24h+) when you request a MSN token update, you get a
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23788
diff
changeset
|
318 | char *data; |
|
024a2801725c
Sometimes (after 24h+) when you request a MSN token update, you get a
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23788
diff
changeset
|
319 | xmlnode *cipher = xmlnode_get_child(node, "RequestedSecurityToken/EncryptedData/CipherData/CipherValue"); |
|
024a2801725c
Sometimes (after 24h+) when you request a MSN token update, you get a
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23788
diff
changeset
|
320 | xmlnode *secret = xmlnode_get_child(node, "RequestedProofToken/BinarySecret"); |
|
23780
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
321 | |
|
23805
024a2801725c
Sometimes (after 24h+) when you request a MSN token update, you get a
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23788
diff
changeset
|
322 | nexus->cipher = xmlnode_get_data(cipher); |
|
024a2801725c
Sometimes (after 24h+) when you request a MSN token update, you get a
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23788
diff
changeset
|
323 | data = xmlnode_get_data(secret); |
|
024a2801725c
Sometimes (after 24h+) when you request a MSN token update, you get a
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23788
diff
changeset
|
324 | nexus->secret = (char *)purple_base64_decode(data, NULL); |
|
024a2801725c
Sometimes (after 24h+) when you request a MSN token update, you get a
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23788
diff
changeset
|
325 | g_free(data); |
|
024a2801725c
Sometimes (after 24h+) when you request a MSN token update, you get a
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23788
diff
changeset
|
326 | |
|
024a2801725c
Sometimes (after 24h+) when you request a MSN token update, you get a
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23788
diff
changeset
|
327 | } else { |
|
024a2801725c
Sometimes (after 24h+) when you request a MSN token update, you get a
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23788
diff
changeset
|
328 | result = nexus_parse_token(nexus, id, node); |
|
024a2801725c
Sometimes (after 24h+) when you request a MSN token update, you get a
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23788
diff
changeset
|
329 | } |
|
024a2801725c
Sometimes (after 24h+) when you request a MSN token update, you get a
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23788
diff
changeset
|
330 | g_free(address); |
|
024a2801725c
Sometimes (after 24h+) when you request a MSN token update, you get a
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23788
diff
changeset
|
331 | } |
| 21358 | 332 | |
|
23756
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
333 | return result; |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
334 | } |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
335 | |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
336 | static void |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
337 | nexus_got_response_cb(MsnSoapMessage *req, MsnSoapMessage *resp, gpointer data) |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
338 | { |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
339 | MsnNexus *nexus = data; |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
340 | MsnSession *session = nexus->session; |
|
23780
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
341 | const char *ticket; |
|
23756
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
342 | char *response; |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
343 | |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
344 | if (resp == NULL) { |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
345 | msn_session_set_error(session, MSN_ERROR_SERVCONN, _("Windows Live ID authentication:Unable to connect")); |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
346 | return; |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
347 | } |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
348 | |
|
23805
024a2801725c
Sometimes (after 24h+) when you request a MSN token update, you get a
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23788
diff
changeset
|
349 | if (!nexus_parse_collection(nexus, -1, |
|
024a2801725c
Sometimes (after 24h+) when you request a MSN token update, you get a
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23788
diff
changeset
|
350 | xmlnode_get_child(resp->xml, |
|
024a2801725c
Sometimes (after 24h+) when you request a MSN token update, you get a
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23788
diff
changeset
|
351 | "Body/RequestSecurityTokenResponseCollection"))) { |
|
23756
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
352 | msn_session_set_error(session, MSN_ERROR_SERVCONN, _("Windows Live ID authentication:Invalid response")); |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
353 | return; |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
354 | } |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
355 | |
|
23780
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
356 | ticket = msn_nexus_get_token_str(nexus, MSN_AUTH_MESSENGER); |
|
23756
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
357 | response = msn_rps_encrypt(nexus); |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
358 | msn_got_login_params(session, ticket, response); |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
359 | g_free(response); |
|
8171
c3c43a25caec
[gaim-migrate @ 8884]
Felipe Contreras <felipe.contreras@gmail.com>
parents:
diff
changeset
|
360 | } |
|
c3c43a25caec
[gaim-migrate @ 8884]
Felipe Contreras <felipe.contreras@gmail.com>
parents:
diff
changeset
|
361 | |
| 13859 | 362 | /*when connect, do the SOAP Style windows Live ID authentication */ |
|
13201
8c224ef70efa
[gaim-migrate @ 15563]
Daniel Atallah <datallah@pidgin.im>
parents:
12457
diff
changeset
|
363 | void |
|
21359
c501751711b0
removed lots of commented out old soap code
Ka-Hing Cheung <khc@pidgin.im>
parents:
21358
diff
changeset
|
364 | msn_nexus_connect(MsnNexus *nexus) |
|
8171
c3c43a25caec
[gaim-migrate @ 8884]
Felipe Contreras <felipe.contreras@gmail.com>
parents:
diff
changeset
|
365 | { |
|
21357
64a63a153c62
the new soap code finally doesn't crash on startup, still can't
Ka-Hing Cheung <khc@pidgin.im>
parents:
20597
diff
changeset
|
366 | MsnSession *session = nexus->session; |
|
23780
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
367 | const char *username; |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
368 | char *password; |
|
23756
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
369 | GString *domains; |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
370 | char *request; |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
371 | int i; |
| 13854 | 372 | |
|
21357
64a63a153c62
the new soap code finally doesn't crash on startup, still can't
Ka-Hing Cheung <khc@pidgin.im>
parents:
20597
diff
changeset
|
373 | MsnSoapMessage *soap; |
|
13201
8c224ef70efa
[gaim-migrate @ 15563]
Daniel Atallah <datallah@pidgin.im>
parents:
12457
diff
changeset
|
374 | |
|
23780
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
375 | purple_debug_info("MSN Nexus","Starting Windows Live ID authentication\n"); |
|
10519
80801a34a246
[gaim-migrate @ 11833]
Stu Tomlinson <nosnilmot@pidgin.im>
parents:
10504
diff
changeset
|
376 | msn_session_set_login_step(session, MSN_LOGIN_STEP_GET_COOKIE); |
|
10481
a5d6b8e1717d
[gaim-migrate @ 11769]
Felipe Contreras <felipe.contreras@gmail.com>
parents:
10345
diff
changeset
|
377 | |
|
23780
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
378 | username = purple_account_get_username(session->account); |
|
21455
25bb99ca43cd
Use only the first 16 characters of the password, and plug a leak.
Ka-Hing Cheung <khc@pidgin.im>
parents:
21431
diff
changeset
|
379 | password = g_strndup(purple_connection_get_password(session->account->gc), 16); |
|
13201
8c224ef70efa
[gaim-migrate @ 15563]
Daniel Atallah <datallah@pidgin.im>
parents:
12457
diff
changeset
|
380 | |
|
23756
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
381 | purple_debug_info("msnp15", "Logging on %s, with policy '%s', nonce '%s'\n", |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
382 | username, nexus->policy, nexus->nonce); |
|
13201
8c224ef70efa
[gaim-migrate @ 15563]
Daniel Atallah <datallah@pidgin.im>
parents:
12457
diff
changeset
|
383 | |
|
23756
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
384 | domains = g_string_new(NULL); |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
385 | for (i = 0; i < nexus->token_len; i++) { |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
386 | g_string_append_printf(domains, MSN_SSO_RST_TEMPLATE, |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
387 | i+1, |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
388 | ticket_domains[i][SSO_VALID_TICKET_DOMAIN], |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
389 | ticket_domains[i][SSO_VALID_TICKET_POLICY] != NULL ? |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
390 | ticket_domains[i][SSO_VALID_TICKET_POLICY] : |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
391 | nexus->policy); |
|
13201
8c224ef70efa
[gaim-migrate @ 15563]
Daniel Atallah <datallah@pidgin.im>
parents:
12457
diff
changeset
|
392 | } |
|
8c224ef70efa
[gaim-migrate @ 15563]
Daniel Atallah <datallah@pidgin.im>
parents:
12457
diff
changeset
|
393 | |
|
23756
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
394 | request = g_strdup_printf(MSN_SSO_TEMPLATE, username, password, domains->str); |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
395 | g_free(password); |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
396 | g_string_free(domains, TRUE); |
|
10481
a5d6b8e1717d
[gaim-migrate @ 11769]
Felipe Contreras <felipe.contreras@gmail.com>
parents:
10345
diff
changeset
|
397 | |
|
23756
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
398 | soap = msn_soap_message_new(NULL, xmlnode_from_str(request, -1)); |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
399 | g_free(request); |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
400 | msn_soap_message_send(session, soap, MSN_SSO_SERVER, SSO_POST_URL, |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
401 | nexus_got_response_cb, nexus); |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
402 | } |
|
12457
6d2633b10f1d
[gaim-migrate @ 14766]
Casey Harkins <charkins@pidgin.im>
parents:
10740
diff
changeset
|
403 | |
|
23756
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
404 | static void |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
405 | nexus_got_update_cb(MsnSoapMessage *req, MsnSoapMessage *resp, gpointer data) |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
406 | { |
|
23780
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
407 | MsnNexusUpdateData *ud = data; |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
408 | MsnNexus *nexus = ud->nexus; |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
409 | char iv[8] = {0,0,0,0,0,0,0,0}; |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
410 | xmlnode *enckey; |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
411 | char *tmp; |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
412 | char *nonce; |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
413 | gsize len; |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
414 | char *key; |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
415 | |
|
23788
b5ab3fd1c440
Finally got MSN token updating working (I think).
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23780
diff
changeset
|
416 | #if 0 |
|
23780
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
417 | char *decrypted_pp; |
|
23788
b5ab3fd1c440
Finally got MSN token updating working (I think).
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23780
diff
changeset
|
418 | #endif |
|
23780
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
419 | char *decrypted_data; |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
420 | |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
421 | purple_debug_info("msnp15", "Got Update Response for %s.\n", ticket_domains[ud->id][SSO_VALID_TICKET_DOMAIN]); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
422 | |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
423 | enckey = xmlnode_get_child(resp->xml, "Header/Security/DerivedKeyToken"); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
424 | while (enckey) { |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
425 | if (g_str_equal(xmlnode_get_attrib(enckey, "Id"), "EncKey")) |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
426 | break; |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
427 | enckey = xmlnode_get_next_twin(enckey); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
428 | } |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
429 | if (!enckey) { |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
430 | purple_debug_info("msnp15", "Invalid Response.\n"); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
431 | return; |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
432 | } |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
433 | |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
434 | tmp = xmlnode_get_data(xmlnode_get_child(enckey, "Nonce")); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
435 | nonce = (char *)purple_base64_decode(tmp, &len); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
436 | key = rps_create_key(nexus->secret, 24, nonce, len); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
437 | g_free(tmp); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
438 | g_free(nonce); |
|
23756
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
439 | |
|
23788
b5ab3fd1c440
Finally got MSN token updating working (I think).
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23780
diff
changeset
|
440 | #if 0 |
|
b5ab3fd1c440
Finally got MSN token updating working (I think).
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23780
diff
changeset
|
441 | /* Don't know what this is for yet */ |
|
23780
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
442 | tmp = xmlnode_get_data(xmlnode_get_child(resp->xml, |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
443 | "Header/EncryptedPP/EncryptedData/CipherData/CipherValue")); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
444 | if (tmp) { |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
445 | decrypted_pp = des3_cbc(key, iv, tmp, len, TRUE); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
446 | g_free(tmp); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
447 | purple_debug_info("msnp15", "Got Response Header EncryptedPP: %s\n", decrypted_pp); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
448 | g_free(decrypted_pp); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
449 | } |
|
23788
b5ab3fd1c440
Finally got MSN token updating working (I think).
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23780
diff
changeset
|
450 | #endif |
|
23780
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
451 | |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
452 | tmp = xmlnode_get_data(xmlnode_get_child(resp->xml, |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
453 | "Body/EncryptedData/CipherData/CipherValue")); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
454 | if (tmp) { |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
455 | char *unescaped; |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
456 | xmlnode *rstresponse; |
|
23788
b5ab3fd1c440
Finally got MSN token updating working (I think).
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23780
diff
changeset
|
457 | |
|
23780
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
458 | unescaped = (char *)purple_base64_decode(tmp, &len); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
459 | g_free(tmp); |
|
23788
b5ab3fd1c440
Finally got MSN token updating working (I think).
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23780
diff
changeset
|
460 | |
|
23780
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
461 | decrypted_data = des3_cbc(key, iv, unescaped, len, TRUE); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
462 | g_free(unescaped); |
|
23788
b5ab3fd1c440
Finally got MSN token updating working (I think).
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23780
diff
changeset
|
463 | purple_debug_info("msnp15", "Got Response Body EncryptedData: %s\n", decrypted_data); |
|
b5ab3fd1c440
Finally got MSN token updating working (I think).
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23780
diff
changeset
|
464 | |
|
23780
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
465 | rstresponse = xmlnode_from_str(decrypted_data, -1); |
|
23805
024a2801725c
Sometimes (after 24h+) when you request a MSN token update, you get a
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23788
diff
changeset
|
466 | if (g_str_equal(rstresponse->name, "RequestSecurityTokenResponse")) |
|
024a2801725c
Sometimes (after 24h+) when you request a MSN token update, you get a
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23788
diff
changeset
|
467 | nexus_parse_token(nexus, ud->id, rstresponse); |
|
024a2801725c
Sometimes (after 24h+) when you request a MSN token update, you get a
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23788
diff
changeset
|
468 | else |
|
024a2801725c
Sometimes (after 24h+) when you request a MSN token update, you get a
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23788
diff
changeset
|
469 | nexus_parse_collection(nexus, ud->id, rstresponse); |
|
23780
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
470 | g_free(decrypted_data); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
471 | } |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
472 | |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
473 | if (ud->cb) |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
474 | purple_timeout_add(0, ud->cb, ud->data); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
475 | |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
476 | g_free(ud); |
|
13201
8c224ef70efa
[gaim-migrate @ 15563]
Daniel Atallah <datallah@pidgin.im>
parents:
12457
diff
changeset
|
477 | } |
|
8171
c3c43a25caec
[gaim-migrate @ 8884]
Felipe Contreras <felipe.contreras@gmail.com>
parents:
diff
changeset
|
478 | |
|
23780
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
479 | void |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
480 | msn_nexus_update_token(MsnNexus *nexus, int id, GSourceFunc cb, gpointer data) |
|
23756
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
481 | { |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
482 | MsnSession *session = nexus->session; |
|
23780
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
483 | MsnNexusUpdateData *ud; |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
484 | PurpleCipherContext *sha1; |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
485 | PurpleCipherContext *hmac; |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
486 | |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
487 | char *key; |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
488 | |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
489 | guchar digest[20]; |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
490 | |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
491 | struct tm *tm; |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
492 | time_t now; |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
493 | char *now_str; |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
494 | char *timestamp; |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
495 | char *timestamp_b64; |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
496 | |
|
23756
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
497 | char *domain; |
|
23780
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
498 | char *domain_b64; |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
499 | |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
500 | char *signedinfo; |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
501 | gint32 nonce[6]; |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
502 | int i; |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
503 | char *nonce_b64; |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
504 | char *signature_b64; |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
505 | guchar signature[20]; |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
506 | |
|
23756
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
507 | char *request; |
|
21357
64a63a153c62
the new soap code finally doesn't crash on startup, still can't
Ka-Hing Cheung <khc@pidgin.im>
parents:
20597
diff
changeset
|
508 | MsnSoapMessage *soap; |
|
13201
8c224ef70efa
[gaim-migrate @ 15563]
Daniel Atallah <datallah@pidgin.im>
parents:
12457
diff
changeset
|
509 | |
|
23780
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
510 | purple_debug_info("msnp15", |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
511 | "Updating ticket for user '%s' on domain '%s'\n", |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
512 | purple_account_get_username(session->account), |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
513 | ticket_domains[id][SSO_VALID_TICKET_DOMAIN]); |
|
13201
8c224ef70efa
[gaim-migrate @ 15563]
Daniel Atallah <datallah@pidgin.im>
parents:
12457
diff
changeset
|
514 | |
|
23780
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
515 | ud = g_new0(MsnNexusUpdateData, 1); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
516 | ud->nexus = nexus; |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
517 | ud->id = id; |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
518 | ud->cb = cb; |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
519 | ud->data = data; |
|
13201
8c224ef70efa
[gaim-migrate @ 15563]
Daniel Atallah <datallah@pidgin.im>
parents:
12457
diff
changeset
|
520 | |
|
23780
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
521 | sha1 = purple_cipher_context_new_by_name("sha1", NULL); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
522 | |
|
23756
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
523 | domain = g_strdup_printf(MSN_SSO_RST_TEMPLATE, |
|
23788
b5ab3fd1c440
Finally got MSN token updating working (I think).
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23780
diff
changeset
|
524 | id, |
|
23780
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
525 | ticket_domains[id][SSO_VALID_TICKET_DOMAIN], |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
526 | ticket_domains[id][SSO_VALID_TICKET_POLICY] != NULL ? |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
527 | ticket_domains[id][SSO_VALID_TICKET_POLICY] : |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
528 | nexus->policy); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
529 | purple_cipher_context_append(sha1, (guchar *)domain, strlen(domain)); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
530 | purple_cipher_context_digest(sha1, 20, digest, NULL); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
531 | domain_b64 = purple_base64_encode(digest, 20); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
532 | |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
533 | now = time(NULL); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
534 | tm = gmtime(&now); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
535 | now_str = g_strdup(purple_utf8_strftime("%Y-%m-%dT%H:%M:%SZ", tm)); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
536 | now += 5*60; |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
537 | tm = gmtime(&now); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
538 | timestamp = g_strdup_printf(MSN_SSO_TIMESTAMP_TEMPLATE, |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
539 | now_str, |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
540 | purple_utf8_strftime("%Y-%m-%dT%H:%M:%SZ", tm)); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
541 | purple_cipher_context_reset(sha1, NULL); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
542 | purple_cipher_context_append(sha1, (guchar *)timestamp, strlen(timestamp)); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
543 | purple_cipher_context_digest(sha1, 20, digest, NULL); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
544 | timestamp_b64 = purple_base64_encode(digest, 20); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
545 | g_free(now_str); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
546 | |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
547 | purple_cipher_context_destroy(sha1); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
548 | |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
549 | signedinfo = g_strdup_printf(MSN_SSO_SIGNEDINFO_TEMPLATE, |
|
23788
b5ab3fd1c440
Finally got MSN token updating working (I think).
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23780
diff
changeset
|
550 | id, |
|
23780
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
551 | domain_b64, |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
552 | timestamp_b64); |
|
10481
a5d6b8e1717d
[gaim-migrate @ 11769]
Felipe Contreras <felipe.contreras@gmail.com>
parents:
10345
diff
changeset
|
553 | |
|
23780
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
554 | for (i = 0; i < 6; i++) |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
555 | nonce[i] = rand(); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
556 | nonce_b64 = purple_base64_encode((guchar *)&nonce, sizeof(nonce)); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
557 | |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
558 | key = rps_create_key(nexus->secret, 24, (char *)nonce, sizeof(nonce)); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
559 | hmac = purple_cipher_context_new_by_name("hmac", NULL); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
560 | purple_cipher_context_set_option(hmac, "hash", "sha1"); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
561 | purple_cipher_context_set_key_with_len(hmac, (guchar *)key, 24); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
562 | purple_cipher_context_append(hmac, (guchar *)signedinfo, strlen(signedinfo)); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
563 | purple_cipher_context_digest(hmac, 20, signature, NULL); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
564 | purple_cipher_context_destroy(hmac); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
565 | signature_b64 = purple_base64_encode(signature, 20); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
566 | |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
567 | request = g_strdup_printf(MSN_SSO_TOKEN_UPDATE_TEMPLATE, |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
568 | nexus->cipher, |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
569 | nonce_b64, |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
570 | timestamp, |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
571 | signedinfo, |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
572 | signature_b64, |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
573 | domain); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
574 | |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
575 | g_free(nonce_b64); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
576 | g_free(domain_b64); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
577 | g_free(timestamp_b64); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
578 | g_free(timestamp); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
579 | g_free(key); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
580 | g_free(signature_b64); |
|
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
581 | g_free(signedinfo); |
|
23756
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
582 | g_free(domain); |
|
12457
6d2633b10f1d
[gaim-migrate @ 14766]
Casey Harkins <charkins@pidgin.im>
parents:
10740
diff
changeset
|
583 | |
|
23756
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
584 | soap = msn_soap_message_new(NULL, xmlnode_from_str(request, -1)); |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
585 | g_free(request); |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
586 | msn_soap_message_send(session, soap, MSN_SSO_SERVER, SSO_POST_URL, |
|
23780
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
587 | nexus_got_update_cb, ud); |
|
13201
8c224ef70efa
[gaim-migrate @ 15563]
Daniel Atallah <datallah@pidgin.im>
parents:
12457
diff
changeset
|
588 | } |
|
8171
c3c43a25caec
[gaim-migrate @ 8884]
Felipe Contreras <felipe.contreras@gmail.com>
parents:
diff
changeset
|
589 | |
|
23756
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
590 | GHashTable * |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
591 | msn_nexus_get_token(MsnNexus *nexus, MsnAuthDomains id) |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
592 | { |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
593 | g_return_val_if_fail(nexus != NULL, NULL); |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
594 | g_return_val_if_fail(id < nexus->token_len, NULL); |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
595 | |
|
23759
1abf46eeccec
fix sending offline message in p15 by sending the correct token. In msnp14,
Ka-Hing Cheung <khc@pidgin.im>
parents:
23756
diff
changeset
|
596 | return nexus->tokens[id].token; |
|
23756
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
597 | } |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
598 | |
|
23759
1abf46eeccec
fix sending offline message in p15 by sending the correct token. In msnp14,
Ka-Hing Cheung <khc@pidgin.im>
parents:
23756
diff
changeset
|
599 | const char * |
|
1abf46eeccec
fix sending offline message in p15 by sending the correct token. In msnp14,
Ka-Hing Cheung <khc@pidgin.im>
parents:
23756
diff
changeset
|
600 | msn_nexus_get_token_str(MsnNexus *nexus, MsnAuthDomains id) |
|
23756
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
601 | { |
|
23759
1abf46eeccec
fix sending offline message in p15 by sending the correct token. In msnp14,
Ka-Hing Cheung <khc@pidgin.im>
parents:
23756
diff
changeset
|
602 | static char buf[1024]; |
|
23756
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
603 | GHashTable *token = msn_nexus_get_token(nexus, id); |
|
23759
1abf46eeccec
fix sending offline message in p15 by sending the correct token. In msnp14,
Ka-Hing Cheung <khc@pidgin.im>
parents:
23756
diff
changeset
|
604 | const char *msn_t; |
|
1abf46eeccec
fix sending offline message in p15 by sending the correct token. In msnp14,
Ka-Hing Cheung <khc@pidgin.im>
parents:
23756
diff
changeset
|
605 | const char *msn_p; |
|
1abf46eeccec
fix sending offline message in p15 by sending the correct token. In msnp14,
Ka-Hing Cheung <khc@pidgin.im>
parents:
23756
diff
changeset
|
606 | gint ret; |
|
23756
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
607 | |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
608 | g_return_val_if_fail(token != NULL, NULL); |
|
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
609 | |
|
23759
1abf46eeccec
fix sending offline message in p15 by sending the correct token. In msnp14,
Ka-Hing Cheung <khc@pidgin.im>
parents:
23756
diff
changeset
|
610 | msn_t = g_hash_table_lookup(token, "t"); |
|
1abf46eeccec
fix sending offline message in p15 by sending the correct token. In msnp14,
Ka-Hing Cheung <khc@pidgin.im>
parents:
23756
diff
changeset
|
611 | msn_p = g_hash_table_lookup(token, "p"); |
|
1abf46eeccec
fix sending offline message in p15 by sending the correct token. In msnp14,
Ka-Hing Cheung <khc@pidgin.im>
parents:
23756
diff
changeset
|
612 | |
|
1abf46eeccec
fix sending offline message in p15 by sending the correct token. In msnp14,
Ka-Hing Cheung <khc@pidgin.im>
parents:
23756
diff
changeset
|
613 | g_return_val_if_fail(msn_t != NULL, NULL); |
|
1abf46eeccec
fix sending offline message in p15 by sending the correct token. In msnp14,
Ka-Hing Cheung <khc@pidgin.im>
parents:
23756
diff
changeset
|
614 | g_return_val_if_fail(msn_p != NULL, NULL); |
|
23756
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
615 | |
|
23780
fda6e23ac6f6
Update MSN nexus functions so that tokens are properly updateable. It
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23773
diff
changeset
|
616 | ret = g_snprintf(buf, sizeof(buf) - 1, "t=%s&p=%s", msn_t, msn_p); |
|
23759
1abf46eeccec
fix sending offline message in p15 by sending the correct token. In msnp14,
Ka-Hing Cheung <khc@pidgin.im>
parents:
23756
diff
changeset
|
617 | g_return_val_if_fail(ret != -1, NULL); |
|
1abf46eeccec
fix sending offline message in p15 by sending the correct token. In msnp14,
Ka-Hing Cheung <khc@pidgin.im>
parents:
23756
diff
changeset
|
618 | |
|
1abf46eeccec
fix sending offline message in p15 by sending the correct token. In msnp14,
Ka-Hing Cheung <khc@pidgin.im>
parents:
23756
diff
changeset
|
619 | return buf; |
|
23756
1569608cab71
Patch 2 from Qulogic, this one adds SSO authentication
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
21679
diff
changeset
|
620 | } |
|
23765
8a43c0d4a095
References #4382, replaces usage of msn_soap_xml_get with xmlnode_get_child
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
23764
diff
changeset
|
621 |