diff options
Diffstat (limited to 'protocols/Steam/src')
-rw-r--r-- | protocols/Steam/src/Steam/message.h | 2 | ||||
-rw-r--r-- | protocols/Steam/src/http_request.h | 4 | ||||
-rw-r--r-- | protocols/Steam/src/steam_account.cpp | 25 | ||||
-rw-r--r-- | protocols/Steam/src/steam_contacts.cpp | 10 | ||||
-rw-r--r-- | protocols/Steam/src/steam_proto.cpp | 22 | ||||
-rw-r--r-- | protocols/Steam/src/steam_proto.h | 1 | ||||
-rw-r--r-- | protocols/Steam/src/steam_thread.cpp | 4 | ||||
-rw-r--r-- | protocols/Steam/src/steam_utils.cpp | 16 |
8 files changed, 53 insertions, 31 deletions
diff --git a/protocols/Steam/src/Steam/message.h b/protocols/Steam/src/Steam/message.h index 389f50b13e..38427d5fcc 100644 --- a/protocols/Steam/src/Steam/message.h +++ b/protocols/Steam/src/Steam/message.h @@ -25,7 +25,7 @@ namespace SteamWebApi char data[256];
mir_snprintf(data, SIZEOF(data),
- "access_token=%s&umqid=%s&persona_state=%i&type=personastate",
+ "access_token=%s&umqid=%s&type=personastate&persona_state=%i",
token,
sessionId,
state);
diff --git a/protocols/Steam/src/http_request.h b/protocols/Steam/src/http_request.h index 8ba2ebffa1..47e9acc3d8 100644 --- a/protocols/Steam/src/http_request.h +++ b/protocols/Steam/src/http_request.h @@ -140,7 +140,9 @@ class SecureHttpRequest : public HttpRequest {
public:
SecureHttpRequest(HANDLE hNetlibUser, int request, LPCSTR url)
- : HttpRequest(hNetlibUser, request, url) { flags = NLHRF_HTTP11 | NLHRF_SSL; }
+ : HttpRequest(hNetlibUser, request, url) {
+ flags = NLHRF_HTTP11 | NLHRF_SSL | NLHRF_NODUMPSEND;
+ }
};
#endif //_HTTP_REQUEST_H_
\ No newline at end of file diff --git a/protocols/Steam/src/steam_account.cpp b/protocols/Steam/src/steam_account.cpp index 17e47887ab..a1261291ea 100644 --- a/protocols/Steam/src/steam_account.cpp +++ b/protocols/Steam/src/steam_account.cpp @@ -16,7 +16,7 @@ bool CSteamProto::IsMe(const char *steamId) void CSteamProto::SetServerStatusThread(void *arg)
{
- WORD status = *((WORD*)arg);
+ WORD status = *((WORD*)&arg);
ptrA token(getStringA("TokenSecret"));
ptrA sessionId(getStringA("SessionID"));
@@ -24,19 +24,27 @@ void CSteamProto::SetServerStatusThread(void *arg) int state = CSteamProto::MirandaToSteamState(status);
// change status
- if (m_iStatus == state)
- return;
-
- int oldStatus = m_iStatus;
- m_iStatus = state;
+ WORD oldStatus = m_iStatus;
+ m_iDesiredStatus = status;
SteamWebApi::MessageApi::SendResult sendResult;
SteamWebApi::MessageApi::SendStatus(m_hNetlibUser, token, sessionId, state, &sendResult);
if (sendResult.IsSuccess())
+ {
+ m_iStatus = status;
ProtoBroadcastAck(NULL, ACKTYPE_STATUS, ACKRESULT_SUCCESS, (HANDLE)oldStatus, m_iStatus);
+ }
else
- m_iStatus = oldStatus;
+ m_iDesiredStatus = m_iStatus;
+}
+
+void CSteamProto::SetServerStatus(WORD status)
+{
+ if (m_iStatus == status)
+ return;
+
+ ForkThread(&CSteamProto::SetServerStatusThread, (void*)status);
}
void CSteamProto::Authorize(SteamWebApi::AuthorizationApi::AuthResult *authResult)
@@ -163,8 +171,7 @@ void CSteamProto::LogInThread(void* param) setDword("MessageID", loginResult.GetMessageId());
// set selected status
- m_iStatus = m_iDesiredStatus;
- ProtoBroadcastAck(NULL, ACKTYPE_STATUS, ACKRESULT_SUCCESS, (HANDLE)ID_STATUS_CONNECTING, m_iDesiredStatus);
+ //CSteamProto::SetServerStatusThread((void*)m_iDesiredStatus);
// load contact list
LoadContactList();
diff --git a/protocols/Steam/src/steam_contacts.cpp b/protocols/Steam/src/steam_contacts.cpp index 52f59ab466..dd461c909c 100644 --- a/protocols/Steam/src/steam_contacts.cpp +++ b/protocols/Steam/src/steam_contacts.cpp @@ -48,6 +48,16 @@ void CSteamProto::UpdateContact(MCONTACT hContact, const SteamWebApi::FriendApi: // only for contacts
if (hContact)
{
+ /*{
+ "type": "personastate",
+ "timestamp" : 130789088,
+ "utc_timestamp" : 1397151246,
+ "steamid_from" : "76561198010620323",
+ "status_flags" : 863,
+ "persona_state" : 4,
+ "persona_name" : "necrostorm"
+ }*/
+
setWord(hContact, "Status", SteamToMirandaStatus(contact->GetState()));
setDword(hContact, "LastEventDateTS", contact->GetLastEvent());
}
diff --git a/protocols/Steam/src/steam_proto.cpp b/protocols/Steam/src/steam_proto.cpp index 94e592e2fb..771d80e96b 100644 --- a/protocols/Steam/src/steam_proto.cpp +++ b/protocols/Steam/src/steam_proto.cpp @@ -106,6 +106,8 @@ DWORD_PTR __cdecl CSteamProto:: GetCaps(int type, MCONTACT hContact) return PF2_ONLINE;
case PFLAGNUM_4:
return PF4_AVATARS;
+ case PFLAGNUM_5:
+ return PF2_SHORTAWAY | PF2_HEAVYDND | PF2_OUTTOLUNCH;
case PFLAG_UNIQUEIDTEXT:
return (DWORD_PTR)Translate("SteamID");
case PFLAG_UNIQUEIDSETTING:
@@ -236,19 +238,19 @@ int CSteamProto::SetStatus(int new_status) m_iStatus = ID_STATUS_CONNECTING;
ForkThread(&CSteamProto::LogInThread, NULL);
}
- else
- {
- if (IsOnline())
- {
- ForkThread(&CSteamProto::SetServerStatusThread, &new_status);
+ //else
+ //{
+ //if (IsOnline())
+ //{
+ // ForkThread(&CSteamProto::SetServerStatusThread, (void*)new_status);
- return 0;
- }
+ // return 0;
+ //}
- ProtoBroadcastAck(NULL, ACKTYPE_STATUS, ACKRESULT_SUCCESS, (HANDLE)old_status, m_iStatus);
+ //ProtoBroadcastAck(NULL, ACKTYPE_STATUS, ACKRESULT_SUCCESS, (HANDLE)old_status, m_iStatus);
- return 0;
- }
+ //return 0;
+ //}
}
ProtoBroadcastAck(NULL, ACKTYPE_STATUS, ACKRESULT_SUCCESS, (HANDLE)old_status, m_iStatus);
diff --git a/protocols/Steam/src/steam_proto.h b/protocols/Steam/src/steam_proto.h index beef8660fa..a4c459bdb9 100644 --- a/protocols/Steam/src/steam_proto.h +++ b/protocols/Steam/src/steam_proto.h @@ -106,6 +106,7 @@ protected: // account
bool IsOnline();
bool IsMe(const char *steamId);
+ void SetServerStatus(WORD status);
void Authorize(SteamWebApi::AuthorizationApi::AuthResult *authResult);
void __cdecl LogInThread(void*);
void __cdecl LogOutThread(void*);
diff --git a/protocols/Steam/src/steam_thread.cpp b/protocols/Steam/src/steam_thread.cpp index e528092d03..c0b410fab0 100644 --- a/protocols/Steam/src/steam_thread.cpp +++ b/protocols/Steam/src/steam_thread.cpp @@ -68,7 +68,9 @@ void CSteamProto::PollStatus(const char *token, const char *sessionId, UINT32 me if (IsMe(steamId))
{
debugLogA("Change own status to %i", status);
- SetStatus(status);
+ WORD oldStatus = m_iStatus;
+ m_iStatus = m_iDesiredStatus = status;
+ ProtoBroadcastAck(NULL, ACKTYPE_STATUS, ACKRESULT_SUCCESS, (HANDLE)oldStatus, m_iStatus);
}
else
{
diff --git a/protocols/Steam/src/steam_utils.cpp b/protocols/Steam/src/steam_utils.cpp index 821d6ef3e1..862164e957 100644 --- a/protocols/Steam/src/steam_utils.cpp +++ b/protocols/Steam/src/steam_utils.cpp @@ -10,10 +10,9 @@ WORD CSteamProto::SteamToMirandaStatus(int state) return ID_STATUS_DND;
case 3: //Away
return ID_STATUS_AWAY;
- /*case 4: //Snoozing
- prim = PURPLE_STATUS_EXTENDED_AWAY;
- break;
- case 5: //Looking to trade
+ case 4: //Playing
+ return PF2_OUTTOLUNCH;
+ /*case 5: //Looking to trade
return "trade";
case 6: //Looking to play
return "play";*/
@@ -33,12 +32,11 @@ int CSteamProto::MirandaToSteamState(int status) return 2; //Busy
case ID_STATUS_AWAY:
return 3; //Away
- /*case 4: //Snoozing
- prim = PURPLE_STATUS_EXTENDED_AWAY;
- break;
- case 5: //Looking to trade
+ /*case PF2_OUTTOLUNCH:
+ return 4; //Playing
+ case 5: //Looking to trade
return "trade";
- case 6: //Looking to play
+ case 6: //Looking to play
return "play";*/
//case 1: //Online
default:
|