summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rwxr-xr-xprotocols/AimOscar/src/connection.cpp69
-rwxr-xr-xprotocols/AimOscar/src/stdafx.h1
2 files changed, 40 insertions, 30 deletions
diff --git a/protocols/AimOscar/src/connection.cpp b/protocols/AimOscar/src/connection.cpp
index 7aac34e2e5..ba5fb521f5 100755
--- a/protocols/AimOscar/src/connection.cpp
+++ b/protocols/AimOscar/src/connection.cpp
@@ -153,20 +153,30 @@ void fill_post_request(char *buf, const char*password, const char* login)
mir_free(_login);
}
-bool parse_clientlogin_response(const char *buf, char *token, char *secret, time_t &hosttime)
+bool parse_clientlogin_response(NETLIBHTTPREQUEST *nlhr, NETLIBHTTPHEADER *my_headers, char *token, char *secret, time_t &hosttime)
{
//TODO: validate response
//TODO: return false on errors
//TODO: extract token, secret, hosttime from response
int datalen = 0;
- wchar_t *buf_w =mir_utf8decodeW(buf);
+ for(int i = 0; i < nlhr->headersCount; i++)
+ {
+ if (!mir_strcmp(nlhr->headers[i].szName, "Set-Cookie"))
+ {
+ my_headers[0].szName = (char*)mir_alloc(mir_strlen("Cookie") + 1);
+ mir_strcpy(my_headers[0].szName, "Cookie");
+ my_headers[0].szValue = (char*)mir_alloc(mir_strlen(nlhr->headers[i].szValue) + 1);
+ mir_strcpy(my_headers[0].szValue, nlhr->headers[i].szValue);
+ }
+ }
+ wchar_t *buf_w =mir_utf8decodeW(nlhr->pData);
HXML root = xmlParseString(buf_w, &datalen, _T(""));
if(!root)
{
mir_free(buf_w);
return false;
}
- HXML status = xmlGetNthChild(root, _T("statusCode"), 0);
+ HXML status = xmlGetChildByPath(root, _T("response/statusCode"), 0);
if(!status)
{
mir_free(buf_w);
@@ -179,21 +189,15 @@ bool parse_clientlogin_response(const char *buf, char *token, char *secret, time
mir_free(buf_w);
return false;
}
- HXML data = xmlGetNthChild(root, _T("data"), 0);
- if(!data)
- {
- mir_free(buf_w);
- return false;
- }
- HXML secret_node = xmlGetNthChild(data, _T("sessionSecret"), 0);
- HXML hosttime_node = xmlGetNthChild(data, _T("hostTime"), 0);
- HXML token_node = xmlGetNthChild(data, _T("token"), 0);
- if(!secret_node || !hosttime_node || !token_node)
+ HXML secret_node = xmlGetChildByPath(root, _T("response/data/sessionSecret"), 0);
+ HXML hosttime_node = xmlGetChildByPath(root, _T("response/data/hostTime"), 0);
+
+ if (!secret_node || !hosttime_node)
{
mir_free(buf_w);
return false;
}
- token_node = xmlGetNthChild(token_node, _T("a"), 0);
+ HXML token_node = xmlGetChildByPath(root, _T("response/data/token/a"), 0);
if(!token_node)
{
mir_free(buf_w);
@@ -245,7 +249,7 @@ void construct_query_string(char *buf, const char *token, time_t hosttime, bool
a=urlencoded_token&distId=0x00000611&f=xml&k=dev_key&ts=hosttime&useTLS=bool_encryption
*/
char *urlencoded_token = mir_urlEncode(token);
- mir_snprintf(buf, 1023, "a=%s&distId=0x00000611&f=xml&k=%s&ts=%d&useTLS=%d", urlencoded_token, AIM_DEFAULT_CLIENT_KEY, hosttime, encryption);
+ mir_snprintf(buf, 1023, "a=%s&distId=%d&f=xml&k=%s&ts=%d&useTLS=%d", urlencoded_token, AIM_DEFAULT_DISTID, AIM_DEFAULT_CLIENT_KEY, hosttime, encryption ? 1 : 0);
mir_free(urlencoded_token);
}
@@ -293,7 +297,7 @@ bool parse_start_socar_session_response(char *response, char *bos_host, unsigned
mir_free(buf_w);
return false;
}
- HXML status = xmlGetNthChild(root, _T("statusCode"), 0);
+ HXML status = xmlGetChildByPath(root, _T("response/statusCode"), 0);
if(!status)
{
mir_free(buf_w);
@@ -306,16 +310,10 @@ bool parse_start_socar_session_response(char *response, char *bos_host, unsigned
mir_free(buf_w);
return false;
}
- HXML data = xmlGetNthChild(root, _T("data"), 0);
- if(!data)
- {
- mir_free(buf_w);
- return false;
- }
- HXML host_node = xmlGetNthChild(data, _T("host"), 0);
- HXML port_node = xmlGetNthChild(data, _T("port"), 0);
- HXML cookie_node = xmlGetNthChild(data, _T("cookie"), 0);
+ HXML host_node = xmlGetChildByPath(root, _T("response/data/host"), 0);
+ HXML port_node = xmlGetChildByPath(root, _T("response/data/port"), 0);
+ HXML cookie_node = xmlGetChildByPath(root, _T("response/data/cookie"), 0);
if(!host_node || !port_node || !cookie_node)
{
mir_free(buf_w);
@@ -354,7 +352,7 @@ bool parse_start_socar_session_response(char *response, char *bos_host, unsigned
mir_free(tmp_host); mir_free(tmp_port); mir_free(tmp_cookie);
if (encryption)
{
- HXML tls_node = xmlGetNthChild(data, _T("tlsCertName"), 0); //tls is optional, so this is not fatal error
+ HXML tls_node = xmlGetChildByPath(root, _T("response/data/tlsCertName"), 0); //tls is optional, so this is not fatal error
if (tls_node)
{
LPCTSTR certname_w = xmlGetText(tls_node);
@@ -381,8 +379,11 @@ void CAimProto::aim_connection_clientlogin(void)
req.requestType = REQUEST_POST;
req.szUrl = AIM_LOGIN_URL;
NETLIBHTTPHEADER headers[1];
- headers[0].szName = "Content-Type";
- headers[0].szValue = "application/x-www-form-urlencoded; charset=UTF-8";
+
+ headers[0].szName = (char*)mir_alloc(mir_strlen("Content-Type") + 1);
+ mir_strcpy(headers[0].szName, "Content-Type");
+ headers[0].szValue = (char*)mir_alloc(mir_strlen("application/x-www-form-urlencoded; charset=UTF-8") + 1);
+ mir_strcpy(headers[0].szValue, "application/x-www-form-urlencoded; charset=UTF-8");
req.headers = headers;
req.headersCount = 1;
char buf[1024];
@@ -394,9 +395,11 @@ void CAimProto::aim_connection_clientlogin(void)
req.pData = buf;
req.dataLength = (int)strlen(buf);
- bool encryption = !getByte(AIM_KEY_DSSL, 0); //TODO: make this configurable
+ bool encryption = !getByte(AIM_KEY_DSSL, 0);
NETLIBHTTPREQUEST *resp = (NETLIBHTTPREQUEST*)CallService(MS_NETLIB_HTTPTRANSACTION, (WPARAM)m_hNetlibUser, (LPARAM)&req);
+ mir_free(headers[0].szName);
+ mir_free(headers[0].szValue);
if(!resp)
{
//TODO: handle error
@@ -415,11 +418,13 @@ void CAimProto::aim_connection_clientlogin(void)
token[0] = 0;
secret[0] = 0;
time_t hosttime;
- if(!parse_clientlogin_response(resp->pData, token, secret, hosttime)) //TODO: check if data nullterminated
+ if(!parse_clientlogin_response(resp, headers, token, secret, hosttime))
{
//TODO: handle error
CallService(MS_NETLIB_FREEHTTPREQUESTSTRUCT, (WPARAM)0, (LPARAM)&resp);
broadcast_status(ID_STATUS_OFFLINE);
+ mir_free(headers[0].szName);
+ mir_free(headers[0].szValue);
mir_free(password);
return;
}
@@ -428,12 +433,16 @@ void CAimProto::aim_connection_clientlogin(void)
req.requestType = REQUEST_GET;
req.pData = NULL;
req.dataLength = 0;
+ //req.headersCount = 1;
+ req.headersCount = 0; //additional headers disabled
char url[2048];
url[0] = 0;
fill_session_url(url, sizeof(url), token, secret, hosttime, password, encryption);
mir_free(password);
req.szUrl = url;
resp = (NETLIBHTTPREQUEST*)CallService(MS_NETLIB_HTTPTRANSACTION, (WPARAM)m_hNetlibUser, (LPARAM)&req);
+ mir_free(headers[0].szName);
+ mir_free(headers[0].szValue);
if(!resp)
{
//TODO: handle error
diff --git a/protocols/AimOscar/src/stdafx.h b/protocols/AimOscar/src/stdafx.h
index e76898dcbf..8adc98a32f 100755
--- a/protocols/AimOscar/src/stdafx.h
+++ b/protocols/AimOscar/src/stdafx.h
@@ -169,6 +169,7 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
#define AIM_LOGIN_URL "https://api.screenname.aol.com/auth/clientLogin"
#define AIM_SESSION_URL "https://api.oscar.aol.com/aim/startOSCARSession"
#define AIM_DEFAULT_CLIENT_KEY "ma15d7JTxbmVG-RP" //this one from libpurple, i am not able to create one, sorry guys
+#define AIM_DEFAULT_DISTID 0x00000611 //this one from libpurple, i am not able to create one, sorry guys
#define AIM_DEFAULT_SERVER "login.oscar.aol.com"
//#define AIM_DEFAULT_SERVER_SSL "slogin.oscar.aol.com"