summaryrefslogtreecommitdiff
path: root/protocols/VKontakte/src/vk_thread.cpp
diff options
context:
space:
mode:
authorSergey Bolhovskoy <elzorfox@ya.ru>2014-09-10 13:15:54 +0000
committerSergey Bolhovskoy <elzorfox@ya.ru>2014-09-10 13:15:54 +0000
commitb8a7168685627ff4ea79dcaf3d917f6b40a23f3b (patch)
treedea3c2f2d883868165d6f4f71ff97fc674f8df9f /protocols/VKontakte/src/vk_thread.cpp
parentf5988c0e4245176f9b3c4380265e70ac2344f62a (diff)
VKontakte:
fix for ‘to many connections’ on FindUser add read status every 60 sec add StatusMsg and About profile fields some cleanup git-svn-id: http://svn.miranda-ng.org/main/trunk@10422 1316c22d-e87f-b044-9b9b-93d7a3e3ba9c
Diffstat (limited to 'protocols/VKontakte/src/vk_thread.cpp')
-rw-r--r--protocols/VKontakte/src/vk_thread.cpp60
1 files changed, 57 insertions, 3 deletions
diff --git a/protocols/VKontakte/src/vk_thread.cpp b/protocols/VKontakte/src/vk_thread.cpp
index 033edb4265..6766ec5ab6 100644
--- a/protocols/VKontakte/src/vk_thread.cpp
+++ b/protocols/VKontakte/src/vk_thread.cpp
@@ -42,8 +42,10 @@ void CVkProto::ConnectionFailed(int iReason)
static VOID CALLBACK TimerProc(HWND, UINT, UINT_PTR, DWORD)
{
- for (int i=0; i < vk_Instances.getCount(); i++)
+ for (int i = 0; i < vk_Instances.getCount(); i++){
vk_Instances[i]->SetServerStatus(vk_Instances[i]->m_iStatus);
+ vk_Instances[i]->RetrieveUsersInfo(1);
+ }
}
static void CALLBACK VKSetTimer(void *pObject)
@@ -228,11 +230,33 @@ void CVkProto::OnReceiveMyInfo(NETLIBHTTPREQUEST *reply, AsyncHttpRequest *pReq)
/////////////////////////////////////////////////////////////////////////////////////////
+static char fieldsName[] = "id, first_name, last_name, photo_100, sex, country, timezone, contacts, online, status, about";
+
void CVkProto::RetrieveUserInfo(LONG userID)
{
Push(new AsyncHttpRequest(this, REQUEST_GET, "/method/users.get.json", true, &CVkProto::OnReceiveUserInfo)
<< INT_PARAM("user_ids", userID)
- << CHAR_PARAM("fields", "id, first_name, last_name, photo_100, sex, country, timezone, contacts, online")
+ << CHAR_PARAM("fields", fieldsName)
+ << CHAR_PARAM("name_case", "nom")
+ << VER_API);
+}
+
+void CVkProto::RetrieveUsersInfo(int flag)
+{
+ CMStringA userIDs;
+ for (MCONTACT hContact = db_find_first(m_szModuleName); hContact; hContact = db_find_next(hContact, m_szModuleName)){
+ LONG userID = getDword(hContact, "ID", -1);
+ if (userID == -1)
+ continue;
+ if (!userIDs.IsEmpty())
+ userIDs.AppendChar(',');
+ userIDs.AppendFormat("%i", userID);
+
+ }
+
+ Push(new AsyncHttpRequest(this, REQUEST_POST, "/method/users.get.json", true, &CVkProto::OnReceiveUserInfo)
+ << CHAR_PARAM("user_ids", userIDs)
+ << CHAR_PARAM("fields", flag?"online,status":fieldsName)
<< CHAR_PARAM("name_case", "nom")
<< VER_API);
}
@@ -264,6 +288,7 @@ void CVkProto::OnReceiveUserInfo(NETLIBHTTPREQUEST *reply, AsyncHttpRequest *pRe
return;
CMString tszNick;
+ int iValue;
ptrT szValue( json_as_string( json_get(pRecord, "first_name")));
if (szValue) {
setTString(hContact, "FirstName", szValue);
@@ -294,6 +319,26 @@ void CVkProto::OnReceiveUserInfo(NETLIBHTTPREQUEST *reply, AsyncHttpRequest *pRe
SetAvatarUrl(hContact, szValue);
setWord(hContact, "Status", (json_as_int(json_get(pRecord, "online")) == 0) ? ID_STATUS_OFFLINE : ID_STATUS_ONLINE);
+
+ if ((iValue = json_as_int(json_get(pRecord, "timezone"))) != 0)
+ setByte(hContact, "Timezone", iValue * -2);
+
+ szValue = json_as_string(json_get(pRecord, "mobile_phone"));
+ if (szValue && *szValue)
+ setTString(hContact, "Cellular", szValue);
+ szValue = json_as_string(json_get(pRecord, "home_phone"));
+ if (szValue && *szValue)
+ setTString(hContact, "Phone", szValue);
+
+ szValue = json_as_string(json_get(pRecord, "status"));
+ if (szValue && *szValue)
+ db_set_ts(hContact, "CList", "StatusMsg", szValue);
+
+ szValue = json_as_string(json_get(pRecord, "about"));
+ if (szValue && *szValue)
+ setTString(hContact, "About", szValue);
+
+
}
}
@@ -304,7 +349,7 @@ void CVkProto::RetrieveFriends()
debugLogA("CVkProto::RetrieveFriends");
Push(new AsyncHttpRequest(this, REQUEST_GET, "/method/friends.get.json", true, &CVkProto::OnReceiveFriends)
<< INT_PARAM("count", 1000)
- << CHAR_PARAM("fields", "id, first_name, last_name, photo_100, sex, country, timezone, contacts, online")
+ << CHAR_PARAM("fields", fieldsName)
<<VER_API);
}
@@ -371,6 +416,14 @@ void CVkProto::OnReceiveFriends(NETLIBHTTPREQUEST *reply, AsyncHttpRequest *pReq
szValue = json_as_string(json_get(pInfo, "home_phone"));
if (szValue && *szValue)
setTString(hContact, "Phone", szValue);
+
+ szValue = json_as_string(json_get(pInfo, "status"));
+ if (szValue && *szValue)
+ db_set_ts(hContact, "CList", "StatusMsg", szValue);
+
+ szValue = json_as_string(json_get(pInfo, "about"));
+ if (szValue && *szValue)
+ setTString(hContact, "About", szValue);
}
if (bCleanContacts)
@@ -487,6 +540,7 @@ void CVkProto::OnReceiveMessages(NETLIBHTTPREQUEST *reply, AsyncHttpRequest *pRe
if (!m_bMarkReadOnReply)
MarkMessagesRead(mids);
+ RetrieveUsersInfo();
}
void CVkProto::OnReceiveDlgs(NETLIBHTTPREQUEST *reply, AsyncHttpRequest *pReq)