summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--protocols/Steam/src/api/session.h10
-rw-r--r--protocols/Steam/src/steam_login.cpp7
-rw-r--r--protocols/Steam/src/steam_proto.cpp3
3 files changed, 18 insertions, 2 deletions
diff --git a/protocols/Steam/src/api/session.h b/protocols/Steam/src/api/session.h
index caf965803e..96fc560816 100644
--- a/protocols/Steam/src/api/session.h
+++ b/protocols/Steam/src/api/session.h
@@ -21,4 +21,14 @@ public:
}
};
+class GetSessionRequest2 : public HttpRequest
+{
+public:
+ GetSessionRequest2() :
+ HttpRequest(REQUEST_GET, STEAM_WEB_URL)
+ {
+ flags = NLHRF_HTTP11 | NLHRF_SSL | NLHRF_NODUMP;
+ }
+};
+
#endif //_STEAM_REQUEST_SESSION_H_
diff --git a/protocols/Steam/src/steam_login.cpp b/protocols/Steam/src/steam_login.cpp
index a063870600..f2d06b208d 100644
--- a/protocols/Steam/src/steam_login.cpp
+++ b/protocols/Steam/src/steam_login.cpp
@@ -262,6 +262,11 @@ void CSteamProto::OnAuthorizationSuccess(const JSONNode &node)
new GetSessionRequest(token.c_str(), steamId.c_str(), cookie.c_str()),
&CSteamProto::OnGotSession);
+ // We need to load homepage to get sessionid cookie
+ PushRequest(
+ new GetSessionRequest2(),
+ &CSteamProto::OnGotSession);
+
PushRequest(
new LogonRequest(token.c_str()),
&CSteamProto::OnLoggedOn);
@@ -269,7 +274,7 @@ void CSteamProto::OnAuthorizationSuccess(const JSONNode &node)
void CSteamProto::OnGotSession(const HttpResponse *response)
{
- if(!response)
+ if (!response)
return;
for (int i = 0; i < response->headersCount; i++)
diff --git a/protocols/Steam/src/steam_proto.cpp b/protocols/Steam/src/steam_proto.cpp
index 8644f9fa50..8d70098aa0 100644
--- a/protocols/Steam/src/steam_proto.cpp
+++ b/protocols/Steam/src/steam_proto.cpp
@@ -325,7 +325,8 @@ int CSteamProto::SetStatus(int new_status)
requestQueue->Start();
ptrA token(getStringA("TokenSecret"));
- if (mir_strlen(token) > 0)
+ ptrA sessionId(getStringA("SessionID"));
+ if (mir_strlen(token) > 0 && mir_strlen(sessionId) > 0)
{
PushRequest(
new LogonRequest(token),