summaryrefslogtreecommitdiff
path: root/protocols
diff options
context:
space:
mode:
Diffstat (limited to 'protocols')
-rw-r--r--protocols/Steam/src/steam_contacts.cpp67
-rw-r--r--protocols/Steam/src/steam_proto.cpp4
2 files changed, 64 insertions, 7 deletions
diff --git a/protocols/Steam/src/steam_contacts.cpp b/protocols/Steam/src/steam_contacts.cpp
index 6ae9a913bf..5724d2a411 100644
--- a/protocols/Steam/src/steam_contacts.cpp
+++ b/protocols/Steam/src/steam_contacts.cpp
@@ -61,10 +61,13 @@ void CSteamProto::UpdateContact(MCONTACT hContact, JSONNODE *data)
// set common data
node = json_get(data, "personaname");
- setWString(hContact, "Nick", json_as_string(node));
+ setTString(hContact, "Nick", json_as_string(node));
node = json_get(data, "profileurl");
- setString(hContact, "Homepage", ptrA(mir_u2a(json_as_string(node))));
+ setString(hContact, "Homepage", _T2A(json_as_string(node)));
+
+ node = json_get(data, "primaryclanid");
+ setString(hContact, "PrimaryClanID", _T2A(json_as_string(node)));
// set name
node = json_get(data, "realname");
@@ -109,9 +112,25 @@ void CSteamProto::UpdateContact(MCONTACT hContact, JSONNODE *data)
else
delSetting(hContact, "Country");
+ // state code
+ node = json_get(data, "locstatecode");
+ if (node)
+ setDword(hContact, "StateCode", json_as_int(node));
+ else
+ delSetting(hContact, "StateCode");
+
+ // city id
+ node = json_get(data, "loccityid");
+ if (node)
+ setDword(hContact, "CityID", json_as_int(node));
+ else
+ delSetting(hContact, "CityID");
+
+ // account created
node = json_get(data, "timecreated");
setDword(hContact, "MemberTS", json_as_int(node));
+ // last logout time
node = json_get(data, "lastlogoff");
setDword(hContact, "LogoffTS", json_as_int(node));
@@ -122,26 +141,60 @@ void CSteamProto::UpdateContact(MCONTACT hContact, JSONNODE *data)
if (hContact != NULL)
setWord(hContact, "Status", status);
+ // client
+ node = json_get(data, "personastateflags");
+ int stateflags = node ? json_as_int(node) : -1;
+ switch (stateflags)
+ {
+ case 0:
+ // nothing special, either standard client or in different status (only online, I want to play, I want to trade statuses support this flags)
+ if (steamStatus == 1 || steamStatus == 5 || steamStatus == 6)
+ setTString(hContact, "MirVer", _T("Steam"));
+ break;
+ case 256:
+ // on website
+ setTString(hContact, "MirVer", _T("Steam (website)"));
+ break;
+ case 512:
+ // on mobile
+ setTString(hContact, "MirVer", _T("Steam (mobile)"));
+ break;
+ default:
+ // none/unknown (e.g. when contact is offline)
+ delSetting(hContact, "MirVer");
+ break;
+ }
+
+ // playing game
node = json_get(data, "gameid");
DWORD gameId = node ? atol(_T2A(json_as_string(node))) : 0;
if (gameId > 0)
{
+ setDword(hContact, "GameID", gameId);
+
node = json_get(data, "gameextrainfo");
- const wchar_t *gameInfo = json_as_string(node);
+ const TCHAR *gameInfo = json_as_string(node);
if (hContact != NULL)
- db_set_ws(hContact, "CList", "StatusMsg", gameInfo);
+ db_set_ts(hContact, "CList", "StatusMsg", gameInfo);
+ setTString(hContact, "GameInfo", gameInfo);
- setWString(hContact, "GameInfo", gameInfo);
- setDword(hContact, "GameID", gameId);
+ node = json_get(data, "gameserverip");
+ setString(hContact, "GameServerIP", _T2A(json_as_string(node)));
+
+ node = json_get(data, "gameserversteamid");
+ setString(hContact, "GameServerID", _T2A(json_as_string(node)));
}
else
{
if (hContact != NULL)
db_unset(hContact, "CList", "StatusMsg");
- delSetting(hContact, "GameInfo");
delSetting(hContact, "GameID");
+ delSetting(hContact, "GameInfo");
+ delSetting(hContact, "GameServerIP");
+ delSetting(hContact, "GameServerID");
+ delSetting(hContact, "GameInfo");
}
}
diff --git a/protocols/Steam/src/steam_proto.cpp b/protocols/Steam/src/steam_proto.cpp
index 778c9f95ee..bd54e140f7 100644
--- a/protocols/Steam/src/steam_proto.cpp
+++ b/protocols/Steam/src/steam_proto.cpp
@@ -37,6 +37,10 @@ CSteamProto::CSteamProto(const char* protoName, const TCHAR* userName) :
// temporary DB settings
db_set_resident(m_szModuleName, "Status"); // NOTE: XStatus cannot be temporary
db_set_resident(m_szModuleName, "IdleTS");
+ db_set_resident(m_szModuleName, "GameID");
+ db_set_resident(m_szModuleName, "GameInfo");
+ db_set_resident(m_szModuleName, "GameServerIP");
+ db_set_resident(m_szModuleName, "GameServerID");
SetAllContactsStatus(ID_STATUS_OFFLINE);